views.py 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530
  1. from django.shortcuts import render
  2. from django.http import HttpResponseRedirect
  3. from django.urls import reverse
  4. from .models import *
  5. from config.views import *
  6. from att.views import *
  7. from .forms import *
  8. from sicurezza.views import *
  9. def welcome(request):
  10. if not 'AdminId' in request.session:
  11. return HttpResponseRedirect(reverse("login:start"))
  12. data = dict()
  13. data['HeaderTitle'] = getConfig('HeaderTitle')
  14. data['Navbar']=True
  15. AdminId = request.session['AdminId']
  16. print('AdminId',AdminId)
  17. admin = Amministratore.objects.get(pk=AdminId)
  18. data['admin'] = admin
  19. print('admin',admin.id,admin.nome)
  20. azienda = None
  21. if 'AziendaId' in request.session:
  22. AziendaId = request.session['AziendaId']
  23. print('AziendaId',AziendaId)
  24. azienda = Azienda.objects.get(pk=AziendaId)
  25. data['azienda'] = azienda
  26. sede = None
  27. if 'SedeId' in request.session:
  28. SedeId = request.session['SedeId']
  29. print('SedeId',SedeId)
  30. try:
  31. sede = Sede.objects.get(pk=SedeId)
  32. except Sede.DoesNotExist as dne:
  33. print("Sede non esiste")
  34. data['sede'] = sede
  35. ### permessi inizio ###
  36. data['permesso'] = getAMP(admin)[0]
  37. if 'AziendaId' in data:
  38. for t in getAZP(data['AziendaId'],admin):
  39. if t not in data['permesso']:
  40. data['permesso'].append(t)
  41. for t in getSEP(data['sede'],admin):
  42. if t not in data['permesso']:
  43. data['permesso'].append(t)
  44. #print('permesso',getAMP(admin)[0])
  45. #print('permesso_azienda',getAZP(data['AziendaId'],admin))
  46. #print('permesso_sede',getSEP(data['sede'],admin))
  47. ### permessi fine ###
  48. ### ricerca delle aziende valide per questo amministratore
  49. assegnazioneazienda = listaAZP(admin)[0]
  50. print('assegnazioneazienda',len(assegnazioneazienda))
  51. if len(assegnazioneazienda) == 1:
  52. ### c'e' una sola azienda,
  53. print(type(assegnazioneazienda[0]))
  54. azienda = Azienda.objects.get(pk=assegnazioneazienda[0].id)
  55. data['azienda'] = azienda
  56. request.session['AziendaId'] = azienda.id
  57. print("Singola Azienda",azienda.nome)
  58. ### lista delle sedi valida per questo amministratore
  59. assegnazionesede=None
  60. if azienda:
  61. assegnazionesede = listaSEP(admin,azienda,"SEDE")
  62. print("assegnazionesede",len(assegnazionesede))
  63. ### lista attività ###
  64. data['listaAttivitaxAmministrazione']=getLogxAmministrazione(admin)
  65. if request.method=="POST":
  66. print(request.POST)
  67. if 'indietro' in request.POST:
  68. print('premuto tast indietro,logout')
  69. return HttpResponseRedirect(reverse("login:start"))
  70. if "sceltaazienda" in request.POST:
  71. sceltaazienda = request.POST.get('sceltaazienda')
  72. try:
  73. sceltaazienda = int(sceltaazienda)
  74. except ValueError as ve:
  75. print("Non e' stata fatta la scelta corretta",ve)
  76. return HttpResponseRedirect(reverse('azienda:welcome'))
  77. print("sceltaazienda = ",request.POST.get('sceltaazienda'))
  78. # attività su nuova/edit azienda
  79. if sceltaazienda == -1: #richiesta una nuova azienda
  80. print('sceltaazienda -1:',sceltaazienda)
  81. if "AziendaId" in request.session:
  82. del request.session['AziendaId']
  83. if "azienda" in request.session:
  84. del request.session['azienda']
  85. if "SedeId" in request.session:
  86. del request.session['SedeId']
  87. if "sede" in request.session:
  88. del request.session['sede']
  89. return HttpResponseRedirect(reverse('azienda:welcome'))
  90. elif sceltaazienda == 0:
  91. print('sceltaazienda 0:',sceltaazienda)
  92. request.session['AziendaIdEdit'] = 0
  93. print('AziendaId',request.session['AziendaIdEdit'])
  94. return HttpResponseRedirect(reverse('azienda:editAzienda'))
  95. else:
  96. try:
  97. azienda = Azienda.objects.get(pk=sceltaazienda)
  98. data['azienda'] = azienda
  99. request.session['AziendaId'] = azienda.id
  100. request.session['SedeId'] = -1
  101. if 'sede' in data:
  102. del data['sede']
  103. except Azienda.DoesNotExist as dne:
  104. print("errore, oggetto inesistente",dne)
  105. if "sceltasede" in request.POST:
  106. sceltasede = request.POST.get('sceltasede')
  107. try:
  108. sceltasede = int(sceltasede)
  109. request.session['SedeId'] = sceltasede
  110. except ValueError as ve:
  111. print("Non e' stata fatta la scelta corretta",ve)
  112. return HttpResponseRedirect(reverse('azienda:welcome'))
  113. print("sceltasede = ",request.POST.get('sceltasede'))
  114. if sceltasede == -1:
  115. print('sceltasede -1:',sceltasede)
  116. if 'sede' in data:
  117. del data['sede']
  118. elif sceltasede == 0: #richiesta una nuova azienda
  119. print('sceltasede 0:',sceltasede)
  120. request.session['SedeIdEdit'] = 0
  121. return HttpResponseRedirect(reverse('azienda:editSede'))
  122. else:
  123. try:
  124. sede = Sede.objects.get(pk=sceltasede)
  125. data['sede'] = sede
  126. request.session['SedeId'] = sede.id
  127. except Sede.DoesNotExist as dne:
  128. print("errore,oggetto inesistente",dne)
  129. if "utenti" in request.POST:
  130. print('premuto tasto utenti')
  131. return HttpResponseRedirect(reverse('utente:welcome'))
  132. if 'documenti' in request.POST:
  133. # stato premuto il tasto documenti
  134. print('premuto tasto documenti')
  135. return HttpResponseRedirect(reverse('documento:welcome'))
  136. if "attivita" in request.POST:
  137. print('premuto tasto attivita')
  138. print("azioenda:",azienda)
  139. data['listaAttivitaxAzienda']=getLogxAzienda(azienda)
  140. if 'comunicazioni' in request.POST:
  141. print('premuto tasto comunicazioni')
  142. return HttpResponseRedirect(reverse('comunicazione:welcome'))
  143. if 'parazienda' in request.POST:
  144. print('premuto tasto Par.Azienda')
  145. azid = request.POST.get('parazienda')
  146. print('azienda passata',request.POST.get('parazienda'))
  147. azienda = Azienda.objects.get(pk=azid)
  148. request.session['AziendaId'] = azienda.id
  149. request.session['AziendaIdEdit'] = azienda.id
  150. return HttpResponseRedirect(reverse('azienda:editAzienda'))
  151. if 'parsede' in request.POST:
  152. print('premuto tasto Par.Sede')
  153. seid = request.POST.get('parsede')
  154. print('sede passata',request.POST.get('parsede'))
  155. sede = Sede.objects.get(pk=seid)
  156. request.session['SedeId'] = sede.id
  157. request.session['SedeIdEdit'] = sede.id
  158. return HttpResponseRedirect(reverse('azienda:editSede'))
  159. if 'amministratore' in request.POST:
  160. print(' premuto tasto Amministratore')
  161. return HttpResponseRedirect(reverse('amministratore:welcome'))
  162. data['AziendaLista'] = assegnazioneazienda
  163. if 'azienda' in data:
  164. print('azienda selezionata:',data['azienda'].nome)
  165. # costruisce la lista delle sedi.
  166. #print(":::",listaSEP(data['azienda'],admin))
  167. data['SedeLista'] = listaSEP(data['azienda'],admin,"SEDE")[0]
  168. #print("::::",data['SedeLista'])
  169. #print(data)
  170. print('numero aziende',len(data['AziendaLista']))
  171. if 'SedeLista' in data:
  172. print('numero di sedi',len(data['SedeLista']))
  173. #for i in data['SedeLista']: print(":::",i.nome)
  174. return render(request,'azienda.welcome.html',data)
  175. # creazione azienda
  176. def editAzienda(request):
  177. if not 'AdminId' in request.session:
  178. return HttpResponseRedirect(reverse("login:start"))
  179. data=dict()
  180. data['HeaderTitle'] = getConfig('HeaderTitle')
  181. data['Navbar']=False
  182. AdminId = request.session['AdminId']
  183. print('AdminId',AdminId)
  184. admin = Amministratore.objects.get(pk=AdminId)
  185. data['admin'] = admin
  186. print('admin',admin.id,admin.nome)
  187. azienda = None
  188. if 'AziendaId' in request.session:
  189. AziendaId = request.session['AziendaId']
  190. print('AziendaId',AziendaId)
  191. azienda = Azienda.objects.get(pk=AziendaId)
  192. data['azienda'] = azienda
  193. sede = None
  194. if 'SedeId' in request.session:
  195. SedeId = request.session['SedeId']
  196. print('SedeId',SedeId)
  197. try:
  198. sede = Sede.objects.get(pk=SedeId)
  199. except Sede.DoesNotExist as dne:
  200. print("Sede non esiste")
  201. data['sede'] = sede
  202. ### azienda su cui effettuare le operazioni
  203. azienda = None
  204. if 'AziendaIdEdit' in request.session:
  205. print('trovato riferimento AziendaIdEdit',request.session.get('AziendaIdEdit'))
  206. azid = request.session.get('AziendaIdEdit')
  207. try:
  208. azienda = Azienda.objects.get(pk=azid)
  209. print('azienda trovata',azienda.nome)
  210. except Azienda.DoesNotExist as dnf:
  211. print(dnf)
  212. azienda = Azienda()
  213. #### permessi ####
  214. data['permesso'] = getAMP(admin)[0]
  215. for t in getAZP(azienda,admin):
  216. if t not in data['permesso']:
  217. data['permesso'].append(t)
  218. if 'sede' in data:
  219. for t in getSEP(data['sede'],admin):
  220. if t not in data['permesso']:
  221. data['permesso'].append(t)
  222. print('permessi:',data['permesso'])
  223. #### permessi ####
  224. if request.method == 'POST':
  225. print('un tasto è stato premuto')
  226. if 'indietro' in request.POST:
  227. return HttpResponseRedirect(reverse('azienda:welcome'))
  228. if 'AggiornaAziendaButton' in request.POST:
  229. print('premuto tasto "AggiornaAziendaButton"')
  230. nuovaazienda = formAzienda(request.POST)
  231. if nuovaazienda.is_valid():
  232. print("il form AggiornaAziendaButton' valido",request.POST)
  233. azienda.nome = nuovaazienda.cleaned_data.get('nome')
  234. azienda.mail = nuovaazienda.cleaned_data.get('mail')
  235. azienda.partitaiva = nuovaazienda.cleaned_data.get('partitaiva')
  236. azienda.cambiopassword = nuovaazienda.cleaned_data.get('cambiopassword')
  237. azienda.forzanuovapassword = nuovaazienda.cleaned_data.get('forzanuovapassword')
  238. azienda.otppassword = nuovaazienda.cleaned_data.get('otppassword')
  239. azienda.save()
  240. request.session['AziendaIdEdit'] = azienda.id
  241. print('azienda:',azienda.id)
  242. request.session['AziendaId'] = azienda.id
  243. data['azienda'] = azienda
  244. ### nel caso l'azienda non esista, si aggiungono i permessi di base
  245. print("data['admin']",data['admin'])
  246. if 'AZIENDA' in getAMP(data['admin'])[0]:
  247. print('getAMP: Azienda')
  248. setAZP(azienda,data['admin'],"AZIENDA")
  249. if 'AZIENDA.CREA' in getAMP(data['admin'])[0]:
  250. print('getAMP: AZIENDA.CREA')
  251. setAZP(azienda,data['admin'],"AZIENDA.CREA")
  252. if 'AZIENDA.EDIT' in getAMP(data['admin'])[0]:
  253. print('getAMP: AZIENDA.EDIT')
  254. setAZP(azienda,data['admin'],"AZIENDA.EDIT")
  255. if 'UTENTE' in getAMP(data['admin'])[0]:
  256. print('getAMP: UTENTE')
  257. setAZP(azienda,data['admin'],"UTENTE")
  258. if 'UTENTE.CREA' in getAMP(data['admin'])[0]:
  259. print('getAMP: UTENTE.CREA')
  260. setAZP(azienda,data['admin'],"UTENTE.CREA")
  261. if 'UTENTE.EDIT' in getAMP(data['admin'])[0]:
  262. print('getAMP: UTENTE.EDIT')
  263. setAZP(azienda,data['admin'],"UTENTE.EDIT")
  264. else:
  265. data['aziendaForm'] = formAzienda(request.POST)
  266. print("il form 'AggiornaAziendaButton' non è valido")
  267. if 'CancellaAziendaPermessiButton' in request.POST:
  268. print('premuto "CancellaAziendaPermessiButton"')
  269. cancellaaziendaamministratoripermessi = request.POST.get('CancellaAziendaPermessiButton')
  270. print('CancellaAziendaAmministratoriPermessi',cancellaaziendaamministratoripermessi)
  271. azp = AZP.objects.get(pk=cancellaaziendaamministratoripermessi)
  272. if azp:
  273. print('Permesso Azienda Amministratore trovato - cancello')
  274. azp.delete()
  275. if 'PermessoDaAggiungereButton' in request.POST:
  276. print('premuto "PermessoDaAggiungereButton"')
  277. formaziendapermessi = formAziendaPermessi(request.POST,amministratori=Amministratore.objects.all())
  278. #formaziendapermessi.c(Amministratore.objects.all()) # alternativa: lista dei soli amministratori con autorizzazione AZIENDA in AMM
  279. #print(formaziendapermessi)
  280. if formaziendapermessi.is_valid():
  281. print('formAziendaPermessi valida')
  282. amministratori = formaziendapermessi.cleaned_data.get('ListaAmministratoriPermessi')
  283. print('amministratori da aggiungere',amministratori)
  284. for x in amministratori:
  285. print('am',amministratori,'az',azienda.nome)
  286. try:
  287. setAZP(azienda,str(x),"AZIENDA")
  288. except ValueError as ve:
  289. print('errore in SETAZP')
  290. else:
  291. print('formAziendaPermessi Errore')
  292. print(formaziendapermessi)
  293. formaziendafield = None
  294. if azienda:
  295. print('Abbiamo azienda',azienda.nome)
  296. tmp = dict()
  297. tmp['id'] = azienda.id
  298. tmp['nome'] = azienda.nome
  299. tmp['partitaiva'] = azienda.partitaiva
  300. tmp['mail'] = azienda.mail
  301. tmp['forzanuovapassword'] = azienda.forzanuovapassword
  302. tmp['cambiopassword'] = azienda.cambiopassword
  303. tmp['otppassword'] = azienda.otppassword
  304. formaziendafield = formAzienda(tmp)
  305. else:
  306. tmp = dict()
  307. tmp['nome'] = ''
  308. tmp['partitaiva'] = ''
  309. tmp['mail'] = user.mail
  310. tmp['forzanuovapassword'] = False
  311. tmp['cambiopassword' ] = False
  312. tmp['otppassword'] = False
  313. formaziendafield = formAzienda(tmp)
  314. data['aziendaForm'] = formaziendafield
  315. data['listaAmministratore'] = listaAMMperAzienda(AziendaId)[1]
  316. print(data['listaAmministratore'])
  317. data['listaAmministratoreDaAggiungere'] = Amministratore.objects.all()
  318. return render(request,'azienda.editAzienda.html',data)
  319. def editSede(request):
  320. if not 'AdminId' in request.session:
  321. return HttpResponseRedirect(reverse("login:start"))
  322. data=dict()
  323. data['HeaderTitle'] = getConfig('HeaderTitle')
  324. data['Navbar']=False
  325. AdminId = request.session['AdminId']
  326. print('AdminId',AdminId)
  327. admin = Amministratore.objects.get(pk=AdminId)
  328. data['admin'] = admin
  329. print('admin',admin.id,admin.nome)
  330. azienda = None
  331. if 'AziendaId' in request.session:
  332. AziendaId = request.session['AziendaId']
  333. print('AziendaId',AziendaId)
  334. azienda = Azienda.objects.get(pk=AziendaId)
  335. data['azienda'] = azienda
  336. sede = None
  337. if 'SedeId' in request.session:
  338. SedeId = request.session['SedeId']
  339. print('SedeId',SedeId)
  340. try:
  341. sede = Sede.objects.get(pk=SedeId)
  342. except Sede.DoesNotExist as dne:
  343. print("Sede non esiste")
  344. data['sede'] = sede
  345. sede = None
  346. if 'SedeIdEdit' in request.session:
  347. print('trovato riferimento SedeIdEdit',request.session.get('SedeIdEdit'))
  348. seid = request.session.get('SedeIdEdit')
  349. try:
  350. sede = Sede.objects.get(pk=seid)
  351. print('sede trovata',sede.nome)
  352. flag = True
  353. except Sede.DoesNotExist as dne:
  354. print('Sede indicata inesistente',dne)
  355. sede = Sede()
  356. sede.azienda = Azienda.objects.get(pk=AziendaId)
  357. print('sede.azienda',sede.azienda.nome)
  358. sede.cambiopassword = sede.azienda.cambiopassword
  359. sede.forzanuovapassword = sede.azienda.forzanuovapassword
  360. sede.otppassword = sede.azienda.otppassword
  361. #### permessi ####
  362. data['permesso'] = getAMP(admin)[0]
  363. for t in getAZP(azienda,admin):
  364. if t not in data['permesso']:
  365. data['permesso'].append(t)
  366. for t in getSEP(data['sede'],admin):
  367. if t not in data['permesso']:
  368. data['permesso'].append(t)
  369. print('permessi:',data['permesso'])
  370. #### permessi ####
  371. if request.method == "POST":
  372. print('un tasto è stato premuto')
  373. if 'indietro' in request.POST:
  374. return HttpResponseRedirect(reverse('azienda:welcome'))
  375. if 'AggiornaSedeButton' in request.POST:
  376. print('premuto tasto "AggiornaSedeButton"')
  377. nuovasede = formSede(request.POST)
  378. if nuovasede.is_valid():
  379. print('il form "formSede" è valido')
  380. sede.nome = nuovasede.cleaned_data.get('nome')
  381. sede.mail = nuovasede.cleaned_data.get('mail')
  382. sede.cambiopassword = nuovasede.cleaned_data.get('cambiopassword')
  383. sede.forzanuovapassword = nuovasede.cleaned_data.get('forzanuovapassword')
  384. sede.otppassword = nuovasede.cleaned_data.get('otppassword')
  385. sede.info = nuovasede.cleaned_data.get('info')
  386. sede.identificativo = nuovasede.cleaned_data.get('identificativo')
  387. sede.save()
  388. request.session['SedeIdEdit'] = sede.id
  389. print('sede:',sede.id)
  390. print('azienda',sede.nome)
  391. request.session['SedeId'] = sede.id
  392. data['sede'] = sede
  393. # nel caso la sede non esista, vediamo di crearla
  394. print("data['admin']",data['admin'])
  395. if 'SEDE' in getAMP(data['admin'])[0]:
  396. print('getAMP: SEDE')
  397. setSEP(sede,data['admin'],"SEDE")
  398. if 'SEDE.CREA' in getAMP(data['admin'])[0]:
  399. print('getAMP: SEDE.CREA')
  400. setSEP(sede,data['admin'],"SEDE.CREA")
  401. if 'SEDE.EDIT' in getAMP(data['admin'])[0]:
  402. print('getAMP: SEDE.EDIT')
  403. setSEP(sede,data['admin'],"SEDE.EDIT")
  404. if 'UTENTE' in getAMP(data['admin'])[0]:
  405. print('getAMP: UTENTE')
  406. setSEP(sede,data['admin'],"UTENTE")
  407. if 'UTENTE.CREA' in getAMP(data['admin'])[0]:
  408. print('getAMP: UTENTE.CREA')
  409. setSEP(sede,data['admin'],"UTENTE.CREA")
  410. if 'UTENTE.EDIT' in getAMP(data['admin'])[0]:
  411. print('getAMP: UTENTE.EDIT')
  412. setSEP(sede,data['admin'],"UTENTE.EDIT")
  413. else:
  414. data['sedeForm'] = formSede(request.POST)
  415. if 'CancellaSedePermessiButton' in request.POST:
  416. print('premuto "CancellaSedePermessiButton"')
  417. cancellasedeamministratoripermessi = request.POST.get('CancellaSedePermessiButton')
  418. print('CancellaSedeAmministratoriPermessi',cancellasedeamministratoripermessi)
  419. sep = SEP.objects.get(pk=cancellasedeamministratoripermessi)
  420. if sep:
  421. print('Permesso Sede Amministratore trovato - cancello')
  422. sep.delete()
  423. if 'PermessoDaAggiungereButton' in request.POST:
  424. print('premuto "PermessoDaAggiungereButton"')
  425. formsedepermessi = formSedePermessi(request.POST,amministratori=Amministratore.objects.all())
  426. #formaziendapermessi.c(Amministratore.objects.all()) # alternativa: lista dei soli amministratori con autorizzazione AZIENDA in AMM
  427. #print(formaziendapermessi)
  428. if formsedepermessi.is_valid():
  429. print('formSedePermessi valida')
  430. amministratori = formsedepermessi.cleaned_data.get('ListaAmministratoriPermessi')
  431. for i in amministratori:
  432. print('amministratori da aggiungere',i)
  433. setSEP(sede,str(i),"SEDE")
  434. else:
  435. print('formSedePermessi Errore')
  436. print(formsedepermessi)
  437. formsedefield = None
  438. if sede:
  439. print('Abbiamo sede',sede.nome)
  440. tmp = dict()
  441. tmp['nome'] = sede.nome
  442. tmp['info'] = sede.info
  443. tmp['identificativo'] = sede.identificativo
  444. tmp['cambiopassword'] = sede.cambiopassword
  445. tmp['forzanuovapassword'] = sede.forzanuovapassword
  446. tmp['otppassword'] = sede.otppassword
  447. print('stato tmp',tmp)
  448. formsedefield = formSede(tmp)
  449. data['sedeForm'] = formsedefield
  450. print("**** sedeId",SedeId)
  451. data['listaAmministratore'] = listaAMMperSede(SedeId)[1]
  452. print("lamm",data['listaAmministratore'])
  453. data['listaAmministratoreDaAggiungere'] = Amministratore.objects.all()
  454. return render(request,'azienda.editSede.html',data)