views.py 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641
  1. from django.shortcuts import render
  2. from django.http import HttpResponseRedirect
  3. from django.db.utils import IntegrityError
  4. from django.urls import reverse
  5. from .models import *
  6. from config.views import *
  7. from config.datafunc import *
  8. from att.views import *
  9. from .forms import *
  10. from sicurezza.views import *
  11. from random import randint
  12. def welcome(request):
  13. if not 'AdminId' in request.session:
  14. return HttpResponseRedirect(reverse("login:start"))
  15. d = DataDict()
  16. data = d.getData()
  17. define = Define(request)
  18. data['admin'] = define.getAdmin()
  19. data['azienda'] = define.getAzienda()
  20. data['AziendaId'] = define.getAziendaId()
  21. data['sede'] = define.getSede()
  22. data['SedeId'] = define.getSedeId()
  23. ### permessi inizio ###
  24. data['permesso'] = getAMP(data['admin'])[0]
  25. print("******",data['azienda'])
  26. if 'azienda' in data:
  27. print('**** azienda presente ****')
  28. for t in getAZP(data['azienda'],data['admin'])[0]:
  29. if t not in data['permesso']:
  30. data['permesso'].append(t)
  31. if 'sede' in data:
  32. print('**** sede presente ****')
  33. for t in getSEP(data['sede'],data['admin']):
  34. if t not in data['permesso']:
  35. data['permesso'].append(t)
  36. print("Permessi Disponibili",data['permesso'])
  37. ### ricerca delle aziende valide per questo amministratore
  38. assegnazioneazienda = listaAZP(data['admin'])[0]
  39. print('assegnazioneazienda',len(assegnazioneazienda))
  40. ### verifica numero di aziende selezionate
  41. if len(assegnazioneazienda) == 1:
  42. print(type(assegnazioneazienda[0]))
  43. azienda = Azienda.objects.get(pk=assegnazioneazienda[0].id)
  44. data['azienda'] = azienda
  45. request.session['AziendaId'] = azienda.id
  46. print("Singola Azienda",azienda.nome)
  47. ### lista delle sedi valida per questo amministratore
  48. assegnazionesede=None
  49. if 'azienda' in data and data['azienda']:
  50. print("Abbiamo l'azienda",data['azienda'].nome)
  51. assegnazionesede = listaSEP(amministratore=data['admin'],azienda=data['azienda'],permesso="SEDE")[0]
  52. ### verifica numero di sedi selezionate
  53. print("assegnazionesede",len(assegnazionesede))
  54. if len(assegnazionesede) == 1:
  55. print("assegnazionesede",assegnazionesede)
  56. #print(assegnazionesede[0])
  57. sede = Sede.objects.get(pk=assegnazionesede[0].id)
  58. print("Sede",sede)
  59. data['sede'] = sede
  60. data['SedeId'] = sede.id
  61. request.session['SedeId'] = sede.id
  62. print("Singola Sede",sede.nome)
  63. ### lista attività ###
  64. data['listaAttivitaxAmministrazione']=getLogxAmministrazione(data['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("azienda:",data['azienda'])
  139. data['listaAttivitaxAzienda']=getLogxAzienda(data['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 'paramm' in request.POST:
  160. print('premuto tasto Par.Amministratore')
  161. amid = request.POST.get('paramm')
  162. print('amministratore passato',request.POST.get('paramm'))
  163. return HttpResponseRedirect(reverse('amministratore:editAmministratore'))
  164. if 'amministratore' in request.POST:
  165. print(' premuto tasto Amministratore')
  166. return HttpResponseRedirect(reverse('amministratore:welcome'))
  167. data['AziendaLista'] = assegnazioneazienda
  168. if 'azienda' in data and data['azienda'] != None:
  169. print('azienda',data['azienda'])
  170. print('azienda selezionata:',data['azienda'].nome)
  171. # costruisce la lista delle sedi.
  172. data['SedeLista'] = listaSEP(data['azienda'],data['admin'],"SEDE")[0]
  173. print('numero aziende',len(data['AziendaLista']))
  174. if 'SedeLista' in data:
  175. print('numero di sedi',len(data['SedeLista']))
  176. #for i in data['SedeLista']: print(":::",i.nome)
  177. ### permessi inizio ###
  178. data['permesso'] = getAMP(data['admin'])[0]
  179. print("******",data['azienda'])
  180. if 'azienda' in data:
  181. print('**** azienda presente ****')
  182. for t in getAZP(data['azienda'],data['admin'])[0]:
  183. if t not in data['permesso']:
  184. data['permesso'].append(t)
  185. if 'sede' in data:
  186. print('**** sede presente ****')
  187. for t in getSEP(data['sede'],data['admin']):
  188. if t not in data['permesso']:
  189. data['permesso'].append(t)
  190. print(data['permesso'])
  191. ### permessi fine ###
  192. return render(request,'azienda.welcome.html',data)
  193. # creazione azienda
  194. def editAzienda(request):
  195. if not 'AdminId' in request.session:
  196. return HttpResponseRedirect(reverse("login:start"))
  197. d = DataDict()
  198. data = d.getData()
  199. define = Define(request)
  200. data['admin'] = define.getAdmin()
  201. data['azienda'] = define.getAzienda()
  202. data['AziendaId'] = define.getAziendaId()
  203. data['sede'] = define.getSede()
  204. data['SedeId'] = define.getSedeId()
  205. data['Navbar'] = False
  206. ### permessi inizio ###
  207. data['permesso'] = getAMP(data['admin'])[0]
  208. print("******",data['azienda'])
  209. if 'azienda' in data:
  210. print('**** azienda presente ****')
  211. for t in getAZP(data['azienda'],data['admin'])[0]:
  212. if t not in data['permesso']:
  213. data['permesso'].append(t)
  214. if 'sede' in data:
  215. print('**** sede presente ****')
  216. for t in getSEP(data['sede'],data['admin']):
  217. if t not in data['permesso']:
  218. data['permesso'].append(t)
  219. print("Permessi Disponibili",data['permesso'])
  220. AdminId = request.session['AdminId']
  221. print('AdminId',AdminId)
  222. admin = Amministratore.objects.get(pk=AdminId)
  223. data['admin'] = admin
  224. print('admin',admin.id,admin.nome)
  225. ### azienda su cui effettuare le operazioni
  226. azienda = None
  227. aziendapresente = False
  228. if 'AziendaIdEdit' in request.session:
  229. print('trovato riferimento AziendaIdEdit',request.session.get('AziendaIdEdit'))
  230. azid = request.session.get('AziendaIdEdit')
  231. try:
  232. azienda = Azienda.objects.get(pk=azid)
  233. aziendapresente = True
  234. print('azienda trovata',azienda.nome)
  235. except Azienda.DoesNotExist as dnf:
  236. print(dnf)
  237. azienda = Azienda()
  238. if request.method == 'POST':
  239. print('un tasto è stato premuto')
  240. if 'indietro' in request.POST:
  241. return HttpResponseRedirect(reverse('azienda:welcome'))
  242. if 'AggiornaAziendaButton' in request.POST:
  243. print('premuto tasto "AggiornaAziendaButton"')
  244. nuovaazienda = formAzienda(request.POST)
  245. if nuovaazienda.is_valid():
  246. print("il form AggiornaAziendaButton' valido",request.POST)
  247. azienda.nome = nuovaazienda.cleaned_data.get('nome')
  248. azienda.mail = nuovaazienda.cleaned_data.get('mail')
  249. azienda.partitaiva = nuovaazienda.cleaned_data.get('partitaiva')
  250. azienda.cambiopassword = nuovaazienda.cleaned_data.get('cambiopassword')
  251. azienda.forzanuovapassword = nuovaazienda.cleaned_data.get('forzanuovapassword')
  252. azienda.otppassword = nuovaazienda.cleaned_data.get('otppassword')
  253. try:
  254. azienda.save()
  255. except IntegrityError as ie:
  256. print("Errore, azienda gia' presente:",azienda.nome,azienda.partitaiva)
  257. data['AziendaEsistente']=True
  258. if not 'AziendaEsistente' in data:
  259. request.session['AziendaIdEdit'] = azienda.id
  260. print('azienda:',azienda.id)
  261. request.session['AziendaId'] = azienda.id
  262. data['azienda'] = azienda
  263. ### generiamo un utente speciale per la gestione dei documenti aziendali
  264. print("Generazione utente speciale per {}".format(azienda.nome))
  265. utente = Utente()
  266. utente.azienda = azienda
  267. utente.special = True
  268. utente.login = azienda.nome
  269. utente.nome = "Document Store: {}".format(azienda.nome)
  270. utente.save()
  271. ### nel caso l'azienda non esista, si aggiungono i permessi di base
  272. print("data['admin']",data['admin'])
  273. if 'AZIENDA' in getAMP(data['admin'])[0]:
  274. print('getAMP: Azienda')
  275. setAZP(azienda,data['admin'],"AZIENDA")
  276. if 'AZIENDA.CREA' in getAMP(data['admin'])[0]:
  277. print('getAMP: AZIENDA.CREA')
  278. setAZP(azienda,data['admin'],"AZIENDA.CREA")
  279. if 'AZIENDA.EDIT' in getAMP(data['admin'])[0]:
  280. print('getAMP: AZIENDA.EDIT')
  281. setAZP(azienda,data['admin'],"AZIENDA.EDIT")
  282. if 'UTENTE' in getAMP(data['admin'])[0]:
  283. print('getAMP: UTENTE')
  284. setAZP(azienda,data['admin'],"UTENTE")
  285. if 'UTENTE.CREA' in getAMP(data['admin'])[0]:
  286. print('getAMP: UTENTE.CREA')
  287. setAZP(azienda,data['admin'],"UTENTE.CREA")
  288. if 'UTENTE.EDIT' in getAMP(data['admin'])[0]:
  289. print('getAMP: UTENTE.EDIT')
  290. setAZP(azienda,data['admin'],"UTENTE.EDIT")
  291. data['aziendaForm'] = formAzienda(request.POST)
  292. return render(request,'azienda.editAzienda.html',data)
  293. else:
  294. data['aziendaForm'] = formAzienda(request.POST)
  295. print("il form 'AggiornaAziendaButton' non è valido")
  296. if 'AvantiAziendaButton' in request.POST:
  297. print('premuto "AvantiAziendaButton"')
  298. ### puo' andare avanti solo se l'azienda gia' e' inserita
  299. if aziendapresente:
  300. print("azienda presente")
  301. return HttpResponseRedirect(reverse('azienda:editAziendaPermesso'))
  302. else:
  303. print("azienda non presente")
  304. formaziendafield = None
  305. if azienda:
  306. print('Abbiamo azienda',azienda.nome)
  307. tmp = dict()
  308. tmp['id'] = azienda.id
  309. tmp['nome'] = azienda.nome
  310. tmp['partitaiva'] = azienda.partitaiva
  311. tmp['mail'] = azienda.mail
  312. tmp['forzanuovapassword'] = azienda.forzanuovapassword
  313. tmp['cambiopassword'] = azienda.cambiopassword
  314. tmp['otppassword'] = azienda.otppassword
  315. formaziendafield = formAzienda(tmp)
  316. else:
  317. tmp = dict()
  318. tmp['nome'] = ''
  319. tmp['partitaiva'] = ''
  320. tmp['mail'] = user.mail
  321. tmp['forzanuovapassword'] = False
  322. tmp['cambiopassword' ] = False
  323. tmp['otppassword'] = False
  324. formaziendafield = formAzienda(tmp)
  325. data['aziendaForm'] = formaziendafield
  326. return render(request,'azienda.editAzienda.html',data)
  327. def editAziendaPermesso(request):
  328. if not 'AdminId' in request.session:
  329. return HttpResponseRedirect(reverse("login:start"))
  330. d = DataDict()
  331. data = d.getData()
  332. define = Define(request)
  333. data['admin'] = define.getAdmin()
  334. data['azienda'] = define.getAzienda()
  335. data['AziendaId'] = define.getAziendaId()
  336. data['sede'] = define.getSede()
  337. data['SedeId'] = define.getSedeId()
  338. data['Navbar'] = False
  339. ### permessi inizio ###
  340. data['permesso'] = getAMP(data['admin'])[0]
  341. print("******",data['azienda'])
  342. if 'azienda' in data:
  343. print('**** azienda presente ****')
  344. for t in getAZP(data['azienda'],data['admin'])[0]:
  345. if t not in data['permesso']:
  346. data['permesso'].append(t)
  347. if 'sede' in data:
  348. print('**** sede presente ****')
  349. for t in getSEP(data['sede'],data['admin']):
  350. if t not in data['permesso']:
  351. data['permesso'].append(t)
  352. print("Permessi Disponibili",data['permesso'])
  353. AziendaId = request.session['AziendaId']
  354. print('AziendaId',AziendaId)
  355. azienda = Azienda.objects.get(pk=AziendaId)
  356. if request.method == 'POST':
  357. print('un tasto è stato premuto')
  358. if 'IndietroAziendaButton' in request.POST:
  359. return HttpResponseRedirect(reverse('azienda:editAzienda'))
  360. if 'FineAziendaButton' in request.POST:
  361. return HttpResponseRedirect(reverse('azienda:welcome'))
  362. if 'PermessoDaAggiungereButton' in request.POST:
  363. print('premuto "PermessoDaAggiungereButton"')
  364. formaziendapermessi = formAziendaPermessi(request.POST,amministratori=Amministratore.objects.all(),permessi=Permesso.objects.all())
  365. if formaziendapermessi.is_valid():
  366. print('formAziendaPermessi valida')
  367. amministratore = formaziendapermessi.cleaned_data.get('ListaAmministratori')
  368. permesso = formaziendapermessi.cleaned_data.get('ListaPermessi')
  369. print('amministratore da aggiungere',amministratore)
  370. print('permesso da aggiungere',permesso)
  371. for a in amministratore:
  372. for p in permesso:
  373. try:
  374. setAZP(azienda,a,Permesso.objects.get(pk=str(p)))
  375. except ValueError as ve:
  376. print('errore in seAZP')
  377. else:
  378. if 'errors' in formaziendapermessi:
  379. print('formAziendaPermessi Errore',formaziendapermessi['errors'])
  380. data['formaziendapermessi'] = formaziendapermessi
  381. if 'AssegnaIdenticiPermessiButton' in request.POST:
  382. print('premuto "AssegnaIdenticiPermessiButton"')
  383. listapermessidisponibili = getAZP(azienda,data['admin'])[0]
  384. print('listapermessidisponibili',listapermessidisponibili)
  385. formaziendapermessi = formAziendaPermessi(request.POST,amministratori=Amministratore.objects.all(),permessi=Permesso.objects.all())
  386. if formaziendapermessi.is_valid():
  387. print('formAziendaPermessi valida')
  388. amministratore = formaziendapermessi.cleaned_data.get('ListaAmministratori')
  389. for p in listapermessidisponibili:
  390. for a in amministratore:
  391. try:
  392. setAZP(azienda,a,p)
  393. except ValueError as ve:
  394. print('errore in setAZP')
  395. if 'CancellaAziendaPermessiButton' in request.POST:
  396. print('premuto "CancellaAziendaPermessiButton"')
  397. cancellaaziendaamministratoripermessi = request.POST.get('CancellaAziendaPermessiButton')
  398. print('CancellaAziendaAmministratoriPermessi',cancellaaziendaamministratoripermessi)
  399. azp = AZP.objects.get(pk=cancellaaziendaamministratoripermessi)
  400. if azp:
  401. print('Permesso Azienda Amministratore trovato - cancello')
  402. azp.delete()
  403. #else:
  404. data['listaAmministratore'] = listaAMMperAzienda(AziendaId)[1]
  405. data['listaAmministratore'] = sorted(data['listaAmministratore'], key = lambda x: x.amministratore.nome,reverse=False)
  406. print("listaAmministratore",len(data['listaAmministratore']))
  407. data['listaAmministratoreDaAggiungere'] = Amministratore.objects.all()
  408. data['listaPermessoDaAggiungere'] = Permesso.objects.filter(classe="AZI")
  409. return render(request,"azienda.editAzienda.permessi.html",data)
  410. def editSede(request):
  411. if not 'AdminId' in request.session:
  412. return HttpResponseRedirect(reverse("login:start"))
  413. data=dict()
  414. data['HeaderTitle'] = getConfig('HeaderTitle')
  415. data['Navbar']=False
  416. AdminId = request.session.get('AdminId')
  417. print('AdminId',AdminId)
  418. admin = Amministratore.objects.get(pk=AdminId)
  419. data['admin'] = admin
  420. print('admin',admin.id,admin.nome)
  421. azienda = None
  422. AziendaId = None
  423. if 'AziendaId' in request.session:
  424. AziendaId = request.session['AziendaId']
  425. print('AziendaId',AziendaId)
  426. azienda = Azienda.objects.get(pk=AziendaId)
  427. data['azienda'] = azienda
  428. sede = None
  429. if 'SedeId' in request.session:
  430. SedeId = request.session['SedeId']
  431. print('SedeId',SedeId)
  432. try:
  433. sede = Sede.objects.get(pk=SedeId)
  434. except Sede.DoesNotExist as dne:
  435. print("Sede non esiste")
  436. data['sede'] = sede
  437. sede = None
  438. if 'SedeIdEdit' in request.session:
  439. print('trovato riferimento SedeIdEdit',request.session.get('SedeIdEdit'))
  440. seid = request.session.get('SedeIdEdit')
  441. try:
  442. sede = Sede.objects.get(pk=seid)
  443. print('sede trovata',sede.nome)
  444. flag = True
  445. except Sede.DoesNotExist as dne:
  446. print('Sede indicata inesistente',dne)
  447. sede = Sede()
  448. sede.azienda = Azienda.objects.get(pk=AziendaId)
  449. print('sede.azienda',sede.azienda.nome)
  450. sede.cambiopassword = sede.azienda.cambiopassword
  451. sede.forzanuovapassword = sede.azienda.forzanuovapassword
  452. sede.otppassword = sede.azienda.otppassword
  453. #### permessi ####
  454. data['permesso'] = getAMP(admin)[0]
  455. for t in getAZP(azienda,admin):
  456. if t not in data['permesso']:
  457. data['permesso'].append(t)
  458. for t in getSEP(data['sede'],admin):
  459. if t not in data['permesso']:
  460. data['permesso'].append(t)
  461. print('permessi:',data['permesso'])
  462. #### permessi ####
  463. if request.method == "POST":
  464. print('un tasto è stato premuto')
  465. if 'indietro' in request.POST:
  466. return HttpResponseRedirect(reverse('azienda:welcome'))
  467. if 'AggiornaSedeButton' in request.POST:
  468. print('premuto tasto "AggiornaSedeButton"')
  469. nuovasede = formSede(request.POST)
  470. if nuovasede.is_valid():
  471. print('il form "formSede" è valido')
  472. sede.nome = nuovasede.cleaned_data.get('nome')
  473. sede.mail = nuovasede.cleaned_data.get('mail')
  474. sede.cambiopassword = nuovasede.cleaned_data.get('cambiopassword')
  475. sede.forzanuovapassword = nuovasede.cleaned_data.get('forzanuovapassword')
  476. sede.otppassword = nuovasede.cleaned_data.get('otppassword')
  477. sede.info = nuovasede.cleaned_data.get('info')
  478. sede.identificativo = nuovasede.cleaned_data.get('identificativo')
  479. sede.save()
  480. request.session['SedeIdEdit'] = sede.id
  481. print('sede:',sede.id)
  482. print('azienda',sede.nome)
  483. request.session['SedeId'] = sede.id
  484. data['sede'] = sede
  485. # nel caso la sede non esista, vediamo di crearla
  486. print("data['admin']",data['admin'])
  487. if 'SEDE' in getAMP(data['admin'])[0]:
  488. print('getAMP: SEDE')
  489. setSEP(sede,data['admin'],"SEDE")
  490. if 'SEDE.CREA' in getAMP(data['admin'])[0]:
  491. print('getAMP: SEDE.CREA')
  492. setSEP(sede,data['admin'],"SEDE.CREA")
  493. if 'SEDE.EDIT' in getAMP(data['admin'])[0]:
  494. print('getAMP: SEDE.EDIT')
  495. setSEP(sede,data['admin'],"SEDE.EDIT")
  496. if 'UTENTE' in getAMP(data['admin'])[0]:
  497. print('getAMP: UTENTE')
  498. setSEP(sede,data['admin'],"UTENTE")
  499. if 'UTENTE.CREA' in getAMP(data['admin'])[0]:
  500. print('getAMP: UTENTE.CREA')
  501. setSEP(sede,data['admin'],"UTENTE.CREA")
  502. if 'UTENTE.EDIT' in getAMP(data['admin'])[0]:
  503. print('getAMP: UTENTE.EDIT')
  504. setSEP(sede,data['admin'],"UTENTE.EDIT")
  505. else:
  506. data['sedeForm'] = formSede(request.POST)
  507. if 'CancellaSedePermessiButton' in request.POST:
  508. print('premuto "CancellaSedePermessiButton"')
  509. cancellasedeamministratoripermessi = request.POST.get('CancellaSedePermessiButton')
  510. print('CancellaSedeAmministratoriPermessi',cancellasedeamministratoripermessi)
  511. sep = SEP.objects.get(pk=cancellasedeamministratoripermessi)
  512. if sep:
  513. print('Permesso Sede Amministratore trovato - cancello')
  514. sep.delete()
  515. if 'PermessoDaAggiungereButton' in request.POST:
  516. print('premuto "PermessoDaAggiungereButton"')
  517. formsedepermessi = formSedePermessi(request.POST,amministratori=Amministratore.objects.all())
  518. #formaziendapermessi.c(Amministratore.objects.all()) # alternativa: lista dei soli amministratori con autorizzazione AZIENDA in AMM
  519. #print(formaziendapermessi)
  520. if formsedepermessi.is_valid():
  521. print('formSedePermessi valida')
  522. amministratori = formsedepermessi.cleaned_data.get('ListaAmministratoriPermessi')
  523. for i in amministratori:
  524. print('amministratori da aggiungere',i)
  525. setSEP(sede,str(i),"SEDE")
  526. else:
  527. print('formSedePermessi Errore')
  528. print(formsedepermessi)
  529. formsedefield = None
  530. if sede:
  531. print('Abbiamo sede',sede.nome)
  532. tmp = dict()
  533. tmp['nome'] = sede.nome
  534. tmp['info'] = sede.info
  535. tmp['identificativo'] = sede.identificativo
  536. tmp['cambiopassword'] = sede.cambiopassword
  537. tmp['forzanuovapassword'] = sede.forzanuovapassword
  538. tmp['otppassword'] = sede.otppassword
  539. print('stato tmp',tmp)
  540. formsedefield = formSede(tmp)
  541. data['sedeForm'] = formsedefield
  542. print("**** sedeId",SedeId)
  543. data['listaAmministratore'] = listaAMMperSede(SedeId)[1]
  544. print("lamm",data['listaAmministratore'])
  545. data['listaAmministratoreDaAggiungere'] = Amministratore.objects.all()
  546. return render(request,'azienda.editSede.html',data)