views.py 23 KB

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