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