534 lines
19 KiB
C#
534 lines
19 KiB
C#
using Microsoft.AspNetCore.Mvc;
|
|
using Newtonsoft.Json;
|
|
using NuGet.Protocol.Plugins;
|
|
using System.Diagnostics;
|
|
using System.Net.Mail;
|
|
using System.Net;
|
|
using System.Reflection;
|
|
using System.Text;
|
|
using VirtualTask.Models;
|
|
using X.PagedList;
|
|
using Humanizer;
|
|
using System.Numerics;
|
|
using System.Reflection.Metadata;
|
|
using System.Threading.Tasks;
|
|
using Microsoft.AspNetCore.Identity;
|
|
using Microsoft.AspNetCore.Mvc.RazorPages;
|
|
using NuGet.Common;
|
|
|
|
namespace VirtualTask.Controllers
|
|
{
|
|
public class RegistrazioniController : Controller
|
|
{
|
|
string apiUrl = string.Empty;
|
|
string urlBase = string.Empty;
|
|
string token = string.Empty;
|
|
string tenant = string.Empty;
|
|
string errMes = string.Empty;
|
|
string admin = string.Empty;
|
|
string urlConfirm = string.Empty;
|
|
|
|
|
|
HttpClient client;
|
|
private readonly IConfiguration _configuration;
|
|
private readonly IHttpContextAccessor _context;
|
|
|
|
public RegistrazioniController(IConfiguration configuration, IHttpContextAccessor context)
|
|
{
|
|
|
|
client = new HttpClient();
|
|
_configuration = configuration;
|
|
var key = _configuration["ApplicationInsights:rootUrlApi"];
|
|
apiUrl = key;
|
|
_context = context;
|
|
var request = _context.HttpContext.Request;
|
|
urlConfirm=_configuration["ApplicationInsights:rootUrl"];
|
|
}
|
|
|
|
#region INDEX
|
|
|
|
public IActionResult Index(string searchString, int? page = 1)
|
|
{
|
|
SessionHelper helper = new SessionHelper(this);
|
|
urlBase = apiUrl + "RegistrazioniList";
|
|
admin = helper.GetStringValue("admin");
|
|
ViewBag.Admin = admin;
|
|
|
|
Uri baseAddress = new Uri(urlBase);
|
|
client = new HttpClient();
|
|
client.BaseAddress = baseAddress;
|
|
|
|
List<Registrazione> modelList = new List<Registrazione>();
|
|
HttpResponseMessage response = client.GetAsync(baseAddress).Result;
|
|
|
|
if (response.IsSuccessStatusCode)
|
|
{
|
|
string data = response.Content.ReadAsStringAsync().Result;
|
|
modelList = JsonConvert.DeserializeObject<List<Registrazione>>(data);
|
|
|
|
if (!string.IsNullOrEmpty(searchString))
|
|
{
|
|
modelList = modelList.Where(s => s.cognome.ToUpper().Contains(searchString.ToUpper())).ToList();
|
|
|
|
ViewData["CurrentFilter"] = searchString;
|
|
}
|
|
else
|
|
{
|
|
ViewData["CurrentFilter"] = null;
|
|
}
|
|
|
|
if (page != null && page < 1)
|
|
{
|
|
page = 1;
|
|
}
|
|
|
|
var pageSize = 10;
|
|
|
|
var shortLinks = modelList
|
|
.OrderByDescending(s => s.id)
|
|
.ToPagedList(page ?? 1, pageSize);
|
|
|
|
return View(shortLinks);
|
|
}
|
|
else
|
|
{
|
|
errMes = response.Content.ReadAsStringAsync().Result;
|
|
helper.SetStringValue("errMsg", errMes);
|
|
return RedirectToAction("Error");
|
|
}
|
|
}
|
|
|
|
#endregion INDEX
|
|
|
|
#region CREATE
|
|
|
|
public IActionResult Create()
|
|
{
|
|
return View();
|
|
}
|
|
|
|
[HttpPost]
|
|
public IActionResult Create(Registrazione model)
|
|
{
|
|
SessionHelper helper = new SessionHelper(this);
|
|
|
|
if (ModelState.IsValid)
|
|
{
|
|
string tokenMail = RandomString(10);
|
|
model.token = tokenMail;
|
|
bool bAziPres = false;
|
|
bAziPres = checkAziendaPresente(model.azienda);
|
|
if (bAziPres)
|
|
{
|
|
ModelState.AddModelError("azienda", "Azienda presente in archivio. Inserire un valore diverso.");
|
|
}
|
|
bool bEmail = model.email.Equals(model.emailConf);
|
|
if (!bEmail)
|
|
{
|
|
ModelState.AddModelError("email", "I campi Email e Conferma Email devono essere uguali");
|
|
}
|
|
|
|
if (!bAziPres && bEmail)
|
|
{
|
|
urlBase = apiUrl + "registrazioni/add";
|
|
Uri baseAddress = new Uri(urlBase);
|
|
client = new HttpClient();
|
|
client.BaseAddress = baseAddress;
|
|
|
|
string data = JsonConvert.SerializeObject(model);
|
|
StringContent content = new StringContent(data, Encoding.UTF8, "application/json");
|
|
HttpResponseMessage response = client.PostAsync(baseAddress, content).Result;
|
|
|
|
if (response.IsSuccessStatusCode)
|
|
{
|
|
//mando mail avvenuta richiesta
|
|
bool esito = MailSent(model.email,model.cognome,model.token);
|
|
return RedirectToAction("RegistrazioneOk");
|
|
}
|
|
else
|
|
{
|
|
errMes = response.Content.ReadAsStringAsync().Result;
|
|
helper.SetStringValue("errMsg", errMes);
|
|
return RedirectToAction("Error");
|
|
}
|
|
}
|
|
else
|
|
{
|
|
return View("Create", model);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
foreach (var Elemento in ModelState.Values)
|
|
{
|
|
foreach (var Errore in Elemento.Errors)
|
|
{
|
|
string ErroreRilevato = Errore.ErrorMessage;
|
|
}
|
|
}
|
|
return View("Create", model);
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
public IActionResult RegistrazioneOk()
|
|
{
|
|
return View();
|
|
}
|
|
|
|
public async Task<ActionResult> ConfirmEmail(string Token, string Email)
|
|
{
|
|
SessionHelper helper = new SessionHelper(this);
|
|
urlBase = apiUrl + "RegistrazioniList";
|
|
admin = helper.GetStringValue("admin");
|
|
ViewBag.Admin = admin;
|
|
|
|
Uri baseAddress = new Uri(urlBase);
|
|
client = new HttpClient();
|
|
client.BaseAddress = baseAddress;
|
|
|
|
List<Registrazione> modelList = new List<Registrazione>();
|
|
HttpResponseMessage response = client.GetAsync(baseAddress).Result;
|
|
|
|
if (response.IsSuccessStatusCode)
|
|
{
|
|
string data = response.Content.ReadAsStringAsync().Result;
|
|
modelList = JsonConvert.DeserializeObject<List<Registrazione>>(data);
|
|
|
|
var reg=modelList.Where(t=>t.email.Equals(Email)&& t.token.Equals(Token)).ToList();
|
|
var trovato = reg.First();
|
|
|
|
UpdRegistrazione(trovato);
|
|
return RedirectToAction("RegistrazioneFinished");
|
|
}
|
|
else
|
|
{
|
|
errMes = response.Content.ReadAsStringAsync().Result;
|
|
helper.SetStringValue("errMsg", errMes);
|
|
return RedirectToAction("Error");
|
|
}
|
|
}
|
|
|
|
public IActionResult RegistrazioneFinished()
|
|
{
|
|
return View();
|
|
}
|
|
#endregion CREATE
|
|
|
|
#region DETAILS
|
|
|
|
public IActionResult Details(int id)
|
|
{
|
|
SessionHelper helper = new SessionHelper(this);
|
|
|
|
urlBase = apiUrl + "registrazioniList";
|
|
//urlBase = "http://10.0.0.187:8000/api/Polo/RegistrazioniList";
|
|
|
|
Uri baseAddress = new Uri(urlBase);
|
|
client = new HttpClient();
|
|
client.BaseAddress = baseAddress;
|
|
admin = helper.GetStringValue("admin");
|
|
ViewBag.Admin = admin;
|
|
Registrazione reg = new Registrazione();
|
|
|
|
List<Registrazione> modelList = new List<Registrazione>();
|
|
|
|
HttpResponseMessage response = client.GetAsync(baseAddress).Result;
|
|
|
|
if (response.IsSuccessStatusCode)
|
|
{
|
|
string data = response.Content.ReadAsStringAsync().Result;
|
|
modelList = JsonConvert.DeserializeObject<List<Registrazione>>(data);
|
|
reg = modelList.Where(x => x.id == id).First();
|
|
}
|
|
else
|
|
{
|
|
errMes = response.Content.ReadAsStringAsync().Result;
|
|
helper.SetStringValue("errMsg", errMes);
|
|
return RedirectToAction("Error");
|
|
}
|
|
return View(reg);
|
|
}
|
|
|
|
#endregion DETAILS
|
|
|
|
#region EDIT
|
|
|
|
public IActionResult Edit(int id)
|
|
{
|
|
SessionHelper helper = new SessionHelper(this);
|
|
|
|
//token = helper.GetStringValue("tok");
|
|
|
|
//apiUrl = helper.GetStringValue("apiUrl");
|
|
//urlBase = apiUrl + "chiusureVtList";
|
|
urlBase = "http://10.0.0.187:8000/api/Polo/RegistrazioniList";
|
|
//urlBase = urlBase + "?token=" + token;
|
|
Uri baseAddress = new Uri(urlBase);
|
|
client = new HttpClient();
|
|
client.BaseAddress = baseAddress;
|
|
admin = helper.GetStringValue("admin");
|
|
ViewBag.Admin = admin;
|
|
Registrazione reg = new Registrazione();
|
|
|
|
List<Registrazione> modelList = new List<Registrazione>();
|
|
|
|
HttpResponseMessage response = client.GetAsync(baseAddress).Result;
|
|
|
|
if (response.IsSuccessStatusCode)
|
|
{
|
|
string data = response.Content.ReadAsStringAsync().Result;
|
|
modelList = JsonConvert.DeserializeObject<List<Registrazione>>(data);
|
|
reg = modelList.Where(x => x.id == id).First();
|
|
}
|
|
else
|
|
{
|
|
errMes = response.Content.ReadAsStringAsync().Result;
|
|
helper.SetStringValue("errMsg", errMes);
|
|
return RedirectToAction("Error");
|
|
}
|
|
|
|
return View(reg);
|
|
}
|
|
|
|
[HttpPost]
|
|
public IActionResult Edit(Registrazione model)
|
|
{
|
|
SessionHelper helper = new SessionHelper(this);
|
|
|
|
//token = helper.GetStringValue("tok");
|
|
//tenant = helper.GetStringValue("tenant");
|
|
//if (string.IsNullOrEmpty(token))
|
|
//{
|
|
// return RedirectToAction("Index", "Login");
|
|
//}
|
|
model.azienda = tenant;
|
|
//apiUrl = helper.GetStringValue("apiUrl");
|
|
//urlBase = apiUrl + "registrazioni/mod";
|
|
urlBase = apiUrl + "http://10.0.0.187:8000/api/Polo/registrazioni/mod";
|
|
//urlBase = urlBase + "?token=" + token;
|
|
Uri baseAddress = new Uri(urlBase);
|
|
client = new HttpClient();
|
|
client.BaseAddress = baseAddress;
|
|
admin = helper.GetStringValue("admin");
|
|
ViewBag.Admin = admin;
|
|
string data = JsonConvert.SerializeObject(model);
|
|
StringContent content = new StringContent(data, Encoding.UTF8, "application/json");
|
|
HttpResponseMessage response = client.PostAsync(baseAddress, content).Result;
|
|
if (response.IsSuccessStatusCode)
|
|
{
|
|
return RedirectToAction("Index");
|
|
}
|
|
else
|
|
{
|
|
errMes = response.Content.ReadAsStringAsync().Result;
|
|
helper.SetStringValue("errMsg", errMes);
|
|
return RedirectToAction("Error");
|
|
}
|
|
}
|
|
|
|
#endregion EDIT
|
|
|
|
#region DELETE
|
|
|
|
[HttpGet]
|
|
public IActionResult Delete(int id)
|
|
{
|
|
SessionHelper helper = new SessionHelper(this);
|
|
|
|
//token = helper.GetStringValue("tok");
|
|
|
|
//apiUrl = helper.GetStringValue("apiUrl");
|
|
//urlBase = apiUrl + "chiusureVtList";
|
|
urlBase = "http://10.0.0.187:8000/api/Polo/RegistrazioniList";
|
|
//urlBase = urlBase + "?token=" + token;
|
|
Uri baseAddress = new Uri(urlBase);
|
|
client = new HttpClient();
|
|
client.BaseAddress = baseAddress;
|
|
|
|
admin = helper.GetStringValue("admin");
|
|
ViewBag.Admin = admin;
|
|
|
|
Registrazione reg = new Registrazione();
|
|
List<Registrazione> modelList = new List<Registrazione>();
|
|
HttpResponseMessage response = client.GetAsync(baseAddress).Result;
|
|
|
|
if (response.IsSuccessStatusCode)
|
|
{
|
|
string data = response.Content.ReadAsStringAsync().Result;
|
|
modelList = JsonConvert.DeserializeObject<List<Registrazione>>(data);
|
|
reg = modelList.Where(x => x.id.Equals(id)).First();
|
|
return View(reg);
|
|
}
|
|
else
|
|
{
|
|
errMes = response.Content.ReadAsStringAsync().Result;
|
|
helper.SetStringValue("errMsg", errMes);
|
|
return RedirectToAction("Error");
|
|
}
|
|
}
|
|
|
|
[HttpPost, ActionName("DeleteConfirmed")]
|
|
public IActionResult DeleteConfirmed(int id)
|
|
{
|
|
SessionHelper helper = new SessionHelper(this);
|
|
|
|
//token = helper.GetStringValue("tok");
|
|
|
|
//apiUrl = helper.GetStringValue("apiUrl");
|
|
urlBase = /*apiUrl + */"http://10.0.0.187:8000/api/Polo/Registrazioni/del?" + "id=" + id /*+ "&"*/;
|
|
//urlBase = urlBase + "token=" + token;
|
|
Uri baseAddress = new Uri(urlBase);
|
|
client = new HttpClient();
|
|
client.BaseAddress = baseAddress;
|
|
|
|
admin = helper.GetStringValue("admin");
|
|
ViewBag.Admin = admin;
|
|
|
|
string data = JsonConvert.SerializeObject(id);
|
|
StringContent content = new StringContent(data, Encoding.UTF8, "application/json");
|
|
|
|
HttpResponseMessage response = client.PostAsync(baseAddress, content).Result;
|
|
|
|
if (response.IsSuccessStatusCode)
|
|
{
|
|
return RedirectToAction("Index");
|
|
}
|
|
else
|
|
{
|
|
errMes = response.Content.ReadAsStringAsync().Result;
|
|
helper.SetStringValue("errMsg", errMes);
|
|
return RedirectToAction("Error");
|
|
}
|
|
}
|
|
|
|
#endregion DELETE
|
|
|
|
[ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
|
|
public IActionResult Error()
|
|
{
|
|
SessionHelper helper = new SessionHelper(this);
|
|
string e = helper.GetStringValue("errMsg");
|
|
return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier, ErrMsg = e });
|
|
}
|
|
private bool checkAziendaPresente(string azienda)
|
|
{
|
|
bool trovato = false;
|
|
bool bAziPres = false;
|
|
|
|
//urlBase = "http://10.0.0.187:8000/api/Polo/AziendePresentiList";
|
|
urlBase = apiUrl + "AziendePresentiList";
|
|
Uri baseAddress = new Uri(urlBase);
|
|
client = new HttpClient();
|
|
client.BaseAddress = baseAddress;
|
|
|
|
List<AziendaPres> modelList = new List<AziendaPres>();
|
|
HttpResponseMessage response = client.GetAsync(baseAddress).Result;
|
|
if (response.IsSuccessStatusCode)
|
|
{
|
|
string data = response.Content.ReadAsStringAsync().Result;
|
|
modelList = JsonConvert.DeserializeObject<List<AziendaPres>>(data);
|
|
foreach(AziendaPres a in modelList)
|
|
{
|
|
if(!string.IsNullOrEmpty(a.tccodazi) && a.tccodazi.Trim().Equals(azienda))
|
|
trovato = true;
|
|
}
|
|
bAziPres = trovato;
|
|
}
|
|
return bAziPres;
|
|
}
|
|
private bool MailSent(string receiver, string nome, string tokenMail)
|
|
{
|
|
//REMEMBER per una mail gmail bisogna andare nelle impostazioni
|
|
//e impostare "Accesso app meno sicure" a ON
|
|
bool sent = false;
|
|
|
|
|
|
string senderMail = _configuration["ApplicationInsights:mittenteMail"];
|
|
string senderName = _configuration["ApplicationInsights:nomeMail"];
|
|
string pwdMail = _configuration["ApplicationInsights:pwdMail"];
|
|
|
|
|
|
string subject = _configuration["ApplicationInsights:subjectMail"];
|
|
string message = getMailText(nome, tokenMail, receiver);
|
|
|
|
var senderEmail = new MailAddress(senderMail, senderName);
|
|
var receiverEmail = new MailAddress(receiver, "Receiver");
|
|
var password = pwdMail;
|
|
var sub = subject;
|
|
var body = message;
|
|
var smtp = new SmtpClient
|
|
{
|
|
Host = "smtp.gmail.com",
|
|
Port = 587,
|
|
EnableSsl = true,
|
|
|
|
DeliveryMethod = SmtpDeliveryMethod.Network,
|
|
UseDefaultCredentials = false,
|
|
Credentials = new NetworkCredential(senderEmail.Address, password)
|
|
};
|
|
using (var mess = new MailMessage(senderEmail, receiverEmail)
|
|
{
|
|
Subject = subject,
|
|
Body = body,
|
|
IsBodyHtml = true
|
|
})
|
|
{
|
|
smtp.Send(mess);
|
|
}
|
|
return sent;
|
|
}
|
|
|
|
private string getMailText(string nome,string tokenEmail, string emailReg)
|
|
{
|
|
string txt = string.Empty;
|
|
StringBuilder sb=new StringBuilder();
|
|
sb.Append(urlConfirm);
|
|
sb.Append("/Registrazioni/ConfirmEmail");
|
|
//sb.Append("https://localhost:7140/Registrazioni/ConfirmEmail");
|
|
sb.Append("?Token=");
|
|
sb.Append(tokenEmail);
|
|
sb.Append("&Email=");
|
|
sb.Append(emailReg);
|
|
|
|
string url = sb.ToString();
|
|
|
|
txt = string.Format("Gentile sig. <b>{0}</b><br> Grazie per essersi registrato. Per completare la registrazione fare click al link: <a href =\"{1}\" title =\"Conferma registrazione\">Conferma</a>", nome, url) ;
|
|
//txt = "<b>titolo contenuto</b><br>contenuto mail di registrazione";
|
|
return txt;
|
|
}
|
|
|
|
private static Random random = new Random();
|
|
|
|
public static string RandomString(int length)
|
|
{
|
|
const string chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
|
|
return new string(Enumerable.Repeat(chars, length)
|
|
.Select(s => s[random.Next(s.Length)]).ToArray());
|
|
}
|
|
|
|
public bool UpdRegistrazione(Registrazione model)
|
|
{
|
|
bool upd=false;
|
|
model.attivato = "S";
|
|
urlBase = apiUrl + "registrazioni/mod";
|
|
Uri baseAddress = new Uri(urlBase);
|
|
client = new HttpClient();
|
|
client.BaseAddress = baseAddress;
|
|
|
|
string data = JsonConvert.SerializeObject(model);
|
|
StringContent content = new StringContent(data, Encoding.UTF8, "application/json");
|
|
HttpResponseMessage response = client.PostAsync(baseAddress, content).Result;
|
|
|
|
if (response.IsSuccessStatusCode)
|
|
{
|
|
upd = true;
|
|
}
|
|
return upd;
|
|
}
|
|
|
|
}
|
|
}
|