views.py 19 KB

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