views.py 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709
  1. from django.shortcuts import render
  2. from .models import *
  3. from .forms import *
  4. from att.views import *
  5. from config.views import *
  6. from random import randint
  7. from django.http import HttpResponse,HttpResponseRedirect
  8. from django.urls import reverse
  9. from sicurezza.views import *
  10. from config.datafunc import *
  11. from django.db.models import Q
  12. def welcome(request):
  13. if not 'AdminId' in request.session:
  14. print("Non rilevo presensa AdminId in request.session")
  15. return HttpResponseRedirect(reverse("login:start"))
  16. ### funzioni esterne ###
  17. d = DataDict()
  18. data = d.getData()
  19. data['NavBar']=True
  20. data['ShowSelectAzienda'] = False
  21. data['ShowSelectSede'] = False
  22. define = Define(request)
  23. data['admin'] = define.getAdmin()
  24. data['azienda'] = define.getAzienda()
  25. data['AziendaId'] = define.getAziendaId()
  26. data['sede'] = define.getSede()
  27. data['SedeId'] = define.getSedeId()
  28. print('cazzo cazzo')
  29. ### funzioni esterne fine ###
  30. ### permessi inizio ###
  31. data['permesso'] = getAMP(data['admin'])[0]
  32. print("******",data['azienda'])
  33. if 'azienda' in data:
  34. print('**** azienda presente ****')
  35. for t in getAZP(data['azienda'],data['admin'])[0]:
  36. if t not in data['permesso']:
  37. data['permesso'].append(t)
  38. if 'sede' in data:
  39. print('**** sede presente ****')
  40. for t in getSEP(data['sede'],data['admin']):
  41. if t not in data['permesso']:
  42. data['permesso'].append(t)
  43. print('permessi assegnati:',data['permesso'])
  44. ### permessi fine ###
  45. amministratorelista = Amministratore.objects.all()
  46. data['amministratorelista'] = amministratorelista
  47. print(len(amministratorelista))
  48. # mostriamo gli amministratori per l'azienda
  49. if data['azienda']:
  50. print('trovato riferimento per azienda')
  51. amministratorelista = data['azienda'].assegnazioneazienda_set.all()
  52. tmp=[]
  53. for al in amministratorelista:
  54. print(al.amministratore.nome)
  55. tmp.append(al.amministratore)
  56. data['amministratorelista'] = tmp
  57. if data['sede']:
  58. print('trovato riferimento per sede')
  59. amministratorelista = data['sede'].assegnazionesede_set.all()
  60. tmp = []
  61. for al in amministratorelista:
  62. try:
  63. print(al.amministratore.nome)
  64. tmp1 = al.amministratore
  65. tmp.append(al.amministratore)
  66. except AttributeError as ae:
  67. print(ae)
  68. data['amministratorelista'] = tmp
  69. data['amministratorelista'] = sorted(data['amministratorelista'], key = lambda x: x.login,reverse=False)
  70. data['amministratorelistalen'] = len(data['amministratorelista'])
  71. if request.method == 'POST':
  72. print("qualcosa e' stato premuto")
  73. if 'indietro' in request.POST:
  74. return HttpResponseRedirect(reverse("azienda:welcome"))
  75. if 'sceltanuovo' in request.POST:
  76. request.session['AmministratoreEditId'] = 0
  77. print('richiesto nuovo record')
  78. return HttpResponseRedirect(reverse('amministratore:edit'))
  79. formamministratoreeditid = FormAmministratoreEditId(request.POST,amministratore=data['amministratorelista'])
  80. if formamministratoreeditid.is_valid():
  81. scelta = formamministratoreeditid.cleaned_data.get('scelta')
  82. request.session['AmministratoreEditId'] = scelta
  83. print("Scelta effettuata",scelta)
  84. return HttpResponseRedirect(reverse("amministratore:edit"))
  85. #data['amministratorelista'] = amministratorelista
  86. #data['numeroRecordAmministratore'] = len(amministratorelista)
  87. #print(data)
  88. return render(request,'amministratore.welcome.html',data)
  89. def edit(request):
  90. '''
  91. edit amministratore o simile
  92. sulla base dei diritti assegnati, puo' leggero e/o scrivere nell'utente
  93. nella sede o nell'azienda.
  94. i diritti sono assegnati sulla base dell'utente e non successivamente
  95. all'assegnazione, tanto se l'utente ha una zona assegnata, quella puo' vedere
  96. e basta.
  97. '''
  98. if not 'AdminId' in request.session:
  99. return HttpResponseRedirect(reverse("login:start"))
  100. data = dict()
  101. data['HeaderTitle'] = getConfig('HeaderTitle')
  102. data['Navbar']=False
  103. if 'AdminId' in request.session:
  104. data['AdminId'] = request.session['AdminId']
  105. admin = Amministratore.objects.get(pk=data['AdminId'])
  106. data['admin'] = admin
  107. print('admin',admin.id,admin.nome)
  108. data['permesso'] = getAMP(admin)[0]
  109. azienda = None
  110. if 'AziendaId' in request.session:
  111. AziendaId = request.session['AziendaId']
  112. print('AziendaId',AziendaId)
  113. azienda = Azienda.objects.get(pk=AziendaId)
  114. data['azienda'] = azienda
  115. sede = None
  116. if 'SedeId' in request.session:
  117. SedeId = request.session['SedeId']
  118. print('SedeId',SedeId)
  119. try:
  120. sede = Sede.objects.get(pk=SedeId)
  121. except Sede.DoesNotExist as dne:
  122. print("Sede non esiste")
  123. data['sede'] = sede
  124. amministratore = None
  125. print(request)
  126. if 'AmministratoreEditId' in request.session:
  127. amministratoreEditId = request.session.get('AmministratoreEditId')
  128. try:
  129. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  130. except Amministratore.DoesNotExist as dne:
  131. amministratore = Amministratore()
  132. amministratore.pin = str(randint(100000,999999))
  133. print('amministratore',amministratore.id,amministratore.nome)
  134. print("request.method",request.method)
  135. if request.method == 'POST':
  136. print("qualcosa e' stato premuto")
  137. if 'indietro' in request.POST:
  138. return HttpResponseRedirect(reverse("amministratore:welcome"))
  139. if 'AmministratoreDirittiAmministratoreButton' in request.POST:
  140. print("Un tasto è stato premuto 'AmministratoreDirittiAmministratoreButton'")
  141. return HttpResponseRedirect(reverse("amministratore:editAMP"))
  142. if 'AmministratoreCancellaButton' in request.POST:
  143. print('editAmministratore: premuto "AmministratoreCancellaButton"')
  144. amp = amministratore.amp_set.all()
  145. azp = amministratore.azp_set.all()
  146. sep = amministratore.sep_set.all()
  147. print(amministratore.nome)
  148. print(len(amp),amp)
  149. print(len(azp),azp)
  150. print(len(sep),sep)
  151. for x in sep:
  152. x.delete()
  153. for x in azp:
  154. x.delete()
  155. for x in amp:
  156. x.delete()
  157. amministratore.delete()
  158. return HttpResponseRedirect(reverse("amministratore:welcome"))
  159. if 'AmministratoreDirittiAziendaButton' in request.POST:
  160. print('edit azienda: premuto "AmministratoreDirittiAziendaButton"')
  161. return HttpResponseRedirect(reverse("amministratore:editAZP"))
  162. if 'AmministratoreUpdateButton' in request.POST:
  163. formamministratore = FormAmministratore(request.POST)
  164. if formamministratore.is_valid():
  165. print('form valida formamministratore')
  166. amministratore.login=formamministratore.cleaned_data.get('login')
  167. amministratore.nome=formamministratore.cleaned_data.get('nome')
  168. amministratore.mail=formamministratore.cleaned_data.get('mail')
  169. amministratore.pin=formamministratore.cleaned_data.get('pin')
  170. amministratore.save()
  171. print('id amministratore salvato/nuovo',amministratore.id,":",amministratore.nome)
  172. request.session['AmministratoreEditId'] = amministratore.id
  173. return HttpResponseRedirect(reverse('amministratore:welcome'))
  174. tmp = dict()
  175. tmp['nome'] = amministratore.nome
  176. tmp['login'] = amministratore.login
  177. tmp['pin'] = amministratore.pin
  178. tmp['mail'] = amministratore.mail
  179. data['amministratore'] = FormAmministratore(tmp)
  180. if amministratore.id:
  181. # elenco aziende autorizzate per amministratore
  182. data['listaazienda'] = listaAZP(amministratore)[0]
  183. print('lista azienda',len(data['listaazienda']))
  184. # elenco dei permessi per amministratore
  185. data['listapermesso'] = getAMP(amministratore)[2]
  186. print('lista permesso',len(data['listapermesso']))
  187. #calcola la differenza tra i permessi assegnati e quelli disponibili
  188. data['listapermessotutto'] = getPermesso()
  189. data['listapermessomancante'] = getAMP(amministratore)[1]
  190. data['listapermessodiff'] = list(set(data['listapermessotutto']) - set(data['listapermessomancante']))
  191. print('Quanti ne mancano',len(data['listapermessodiff']),data['listapermessodiff'])
  192. #calcolo la differenza tra tutte le aziende e le aziende sottoposte a permesso
  193. listaaziendatutte = Azienda.objects.all()
  194. data['listaaziendadiff'] = list(set(listaaziendatutte)-set(data['listaazienda']))
  195. print('Differenza aziende',len(data['listaaziendadiff']))
  196. return render(request,'amministratore.edit.html',data)
  197. def editAMP(request):
  198. ### consente di aggiornare i diritti a livello di amministratore ###
  199. if not 'AdminId' in request.session:
  200. return HttpResponseRedirect(reverse("login:start"))
  201. ### funzioni esterne ###
  202. d = DataDict()
  203. data = d.getData()
  204. data['NavBar']=True
  205. data['ShowSelectAzienda'] = False
  206. data['ShowSelectSede'] = False
  207. define = Define(request)
  208. data['admin'] = define.getAdmin()
  209. data['azienda'] = define.getAzienda()
  210. data['AziendaId'] = define.getAziendaId()
  211. data['sede'] = define.getSede()
  212. data['SedeId'] = define.getSedeId()
  213. ### funzioni esterne fine ###
  214. if 'AdminId' in request.session:
  215. data['AdminId'] = request.session['AdminId']
  216. admin = Amministratore.objects.get(pk=data['AdminId'])
  217. data['admin'] = admin
  218. print('admin',admin.id,admin.nome)
  219. data['permesso'] = getAMP(admin)[0]
  220. amministratore = None
  221. if 'AmministratoreEditId' in request.session:
  222. amministratoreEditId = request.session.get('AmministratoreEditId')
  223. try:
  224. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  225. except Amministratore.DoesNotExist as dne:
  226. return HttpResponseRedirect(reverse("amministratore:edit"))
  227. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  228. data['amministratore'] = amministratore
  229. data['listapermessiassegnati'] = getAMP(data['amministratore'])[1]
  230. print('listapermessiassegnati',data['listapermessiassegnati'])
  231. data['listapermessiassegnabili'] = Permesso.objects.all()
  232. print('listapermessiassegnabili',data['listapermessiassegnabili'])
  233. if request.method == 'POST':
  234. if 'AmministratoreButton' in request.POST:
  235. print("Un tasto è stato premuto 'AmministratoreButton'")
  236. return HttpResponseRedirect(reverse("amministratore:edit"))
  237. if 'AmministratoreReturnButton' in request.POST:
  238. print("Un tasto èstato premuto 'AmministratoreReturnButton'")
  239. return HttpResponseRedirect(reverse("amministratore:welcome"))
  240. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST,permessi=data['listapermessiassegnabili'])
  241. if formpermessodaaggiungere.is_valid():
  242. print('formpermessodaaggiungere valido')
  243. permesso = formpermessodaaggiungere.cleaned_data.get('ListaPermessiDaAggiungere')
  244. print('*' * 10)
  245. setAMP(amministratore,int(permesso))
  246. print('*' * 10)
  247. else:
  248. print('non va: formpermessodaaggiungere',formpermessodaaggiungere)
  249. print('*' * 20)
  250. formpermessodarimuovere = FormPermessoDaRimuovere(request.POST)
  251. if formpermessodarimuovere.is_valid():
  252. print('formpermessodarimuovere valido')
  253. permesso = formpermessodarimuovere.cleaned_data.get('ConfermaCancellazionePermesso')
  254. print('ConfermaCancellazionePermesso',permesso)
  255. delAMP(amministratore,permesso)
  256. else:
  257. print('non va: formpermessodarimuovere',formpermessodarimuovere)
  258. else:
  259. print('che merda do operazione')
  260. print(request.POST)
  261. data['listapermessiassegnati'] = getAMP(data['amministratore'])[1]
  262. print('listapermessiassegnati',data['listapermessiassegnati'])
  263. data['listapermessiassegnabili'] = Permesso.objects.all()
  264. print('listapermessiassegnabili',data['listapermessiassegnabili'])
  265. return render(request,'amministratore.edit.AMP.html',data)
  266. def editAZP(request):
  267. ### edit diritti associati all'azienda.
  268. ### in questa sezione procediamo con l'assegnare o rimuovere i diritti di questo amministratore
  269. ### per le aziende in elenco.
  270. if not 'AdminId' in request.session:
  271. return HttpResponseRedirect(reverse("login:start"))
  272. ### funzioni esterne ###
  273. d = DataDict()
  274. data = d.getData()
  275. data['NavBar']=True
  276. data['ShowSelectAzienda'] = False
  277. data['ShowSelectSede'] = False
  278. define = Define(request)
  279. data['admin'] = define.getAdmin()
  280. data['azienda'] = define.getAzienda()
  281. data['AziendaId'] = define.getAziendaId()
  282. data['sede'] = define.getSede()
  283. data['SedeId'] = define.getSedeId()
  284. ### funzioni esterne fine ###
  285. if 'AdminId' in request.session:
  286. data['AdminId'] = request.session['AdminId']
  287. admin = Amministratore.objects.get(pk=data['AdminId'])
  288. data['admin'] = admin
  289. print('admin',admin.id,admin.nome)
  290. data['permesso'] = getAMP(admin)[0]
  291. listaaziendatutte = Azienda.objects.all()
  292. amministratore = None
  293. if 'AmministratoreEditId' in request.session:
  294. amministratoreEditId = request.session.get('AmministratoreEditId')
  295. try:
  296. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  297. except Amministratore.DoesNotExist as dne:
  298. return HttpResponseRedirect(reverse("amministratore:edit"))
  299. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  300. data['amministratore'] = amministratore
  301. if amministratore:
  302. data['listaazienda'] = listaAZP(amministratore)[0]
  303. data['listaaziendadiff'] = list(set(listaaziendatutte)-set(data['listaazienda']))
  304. else:
  305. data['listaaziendadiff'] = list(set(listaaziendatutte))
  306. #parliamo di diritti assegnati all'azienda.
  307. data['dirittiAZIENDA'] = Permesso.objects.filter(Q(classe='AZI')|Q(classe='SED'))
  308. print('dirittiAZIENDA',len(data['dirittiAZIENDA']))
  309. if request.method == 'POST':
  310. print("qualcosa e' stato premuto")
  311. if 'AmministratoreReturnButton' in request.POST:
  312. print("Un tasto è stato premuto 'AmministratoreReturnButton'")
  313. return HttpResponseRedirect(reverse("amministratore:welcome"))
  314. if 'AmministratoreButton' in request.POST:
  315. print("Un tasto è stato premuto 'AmministratoreButton'")
  316. return HttpResponseRedirect(reverse("amministratore:edit"))
  317. if 'AziendaDaAggiungereButton' in request.POST:
  318. print('un tasto è stato premuto AziendaDaAggiungereButton')
  319. formaziendadaaggiungere = FormAziendaDaAggiungere(request.POST,azienda=listaaziendatutte)
  320. if formaziendadaaggiungere.is_valid():
  321. print('AziendaDaAggiungere, form valida')
  322. azienda = formaziendadaaggiungere.cleaned_data.get('ListaAziendaDaAggiungere')
  323. print(azienda)
  324. setAZP(azienda,amministratore,'AZIENDA')
  325. else:
  326. print('AziendaDaAggiungere, form non valido')
  327. if 'SedeButton' in request.POST:
  328. print("Un tasto è stato premuto 'SedeButton'")
  329. azienda = request.POST.get('SedeButton')
  330. request.session['EditAziendaId'] = azienda
  331. return HttpResponseRedirect(reverse("amministratore:editSEP"))
  332. if 'AziendaPermessoUpdateButton' in request.POST:
  333. print("Un tasto è stato premuto 'AziendaPermessoUpdate'")
  334. print(request.POST)
  335. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST)
  336. formpermessodaaggiungere.c(Permesso.objects.filter(classe="SED"))
  337. if formpermessodaaggiungere.is_valid():
  338. print('formpermessodaaggiungere è valido')
  339. print("cazzo cazzo")
  340. else:
  341. print('errore',formpermessodaaggiungere)
  342. #formpermessoupdate = form.PermessoUpdate(request.POST)
  343. if amministratore:
  344. data['listaazienda'] = listaAZP(amministratore)[0]
  345. data['listaaziendadiff'] = list(set(listaaziendatutte)-set(data['listaazienda']))
  346. else:
  347. data['listaaziendadiff'] = list(set(listaaziendatutte))
  348. return render(request,'amministratore.edit.AZP.html',data)
  349. def editSEP(request):
  350. ### edit diritti associati alla sede
  351. ### in questa sezione procediamo con l'assegnare o rimuovere i diritti di questo amministratore
  352. ### per le sedi in elenco.
  353. if not 'AdminId' in request.session:
  354. return HttpResponseRedirect(reverse("login:start"))
  355. ### funzioni esterne ###
  356. d = DataDict()
  357. data = d.getData()
  358. data['NavBar']=True
  359. data['ShowSelectAzienda'] = False
  360. data['ShowSelectSede'] = False
  361. define = Define(request)
  362. data['admin'] = define.getAdmin()
  363. data['azienda'] = define.getAzienda()
  364. data['AziendaId'] = define.getAziendaId()
  365. data['sede'] = define.getSede()
  366. data['SedeId'] = define.getSedeId()
  367. ### funzioni esterne fine ###
  368. if not 'EditAziendaId' in request.session:
  369. HttpResponseRedirect(reverse("amministratore:editAZP"))
  370. if 'AdminId' in request.session:
  371. data['AdminId'] = request.session['AdminId']
  372. admin = Amministratore.objects.get(pk=data['AdminId'])
  373. data['admin'] = admin
  374. print('admin',admin.id,admin.nome)
  375. data['permesso'] = getAMP(admin)[0]
  376. amministratore = None
  377. if 'AmministratoreEditId' in request.session:
  378. amministratoreEditId = request.session.get('AmministratoreEditId')
  379. try:
  380. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  381. except Amministratore.DoesNotExist as dne:
  382. return HttpResponseRedirect(reverse("amministratore:editSEP"))
  383. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  384. data['amministratore'] = amministratore
  385. azienda = Azienda.objects.get(pk=request.session.get('EditAziendaId'))
  386. print('azienda',azienda.nome)
  387. data['aziendaOnWork'] = azienda
  388. data['listasede'] = listaSEP(azienda,amministratore.id,"SEDE")[0]
  389. print("data['listasede']",len(data['listasede']))
  390. listasedetutte = azienda.sede_set.all()
  391. print('listasedetutte',len(listasedetutte))
  392. data['listasedediff'] = list(set(listasedetutte)-set(data['listasede']))
  393. #data['listasedediff'] = listasedetutte
  394. print("data['listasedediff']",len(data['listasedediff']))
  395. # parliamo di diritti relativi alle sedi
  396. data['dirittiSEDE'] = Permesso.objects.filter(classe='SED')
  397. print('dirittiSEDE',len(data['dirittiSEDE']))
  398. print('minchia')
  399. if request.method == 'POST':
  400. print("qualcosa e' stato premuto")
  401. if 'AmministratoreReturnButton' in request.POST:
  402. print("Un tasto è stato premuto 'AmministratoreReturnButton'")
  403. return HttpResponseRedirect(reverse("amministratore:welcome"))
  404. if 'AmministratoreButton' in request.POST:
  405. print("Un tasto è stato premuto 'AmministratoreButton'")
  406. return HttpResponseRedirect(reverse("amministratore:edit"))
  407. if 'AmministratoreEditAZPButton' in request.POST:
  408. print("Un tasto èstato premuto 'AmministratoreEditAZPButton'")
  409. return HttpResponseRedirect(reverse("amministratore:editAZP"))
  410. if 'SedeDaAggiungereButton' in request.POST:
  411. print('un tasto è stato premuto SedeDaAggiungereButton')
  412. formsededaaggiungere = FormSedeDaAggiungere(request.POST,sede=data['listasedediff'])
  413. if formsededaaggiungere.is_valid():
  414. print('SedeDaAggiungere, form valida')
  415. sede = formsededaaggiungere.cleaned_data.get('ListaSedeDaAggiungere')
  416. print(sede)
  417. setSEP(sede,amministratore,'SEDE')
  418. else:
  419. print('SedeDaAggiungere, form non valido')
  420. if 'SedePermessoUpdateButton' in request.POST:
  421. print("Un tasto è stato premuto 'SedePermessoUpdate'")
  422. print(request.POST)
  423. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST)
  424. formpermessodaaggiungere.c(Permesso.objects.filter(classe="SED"))
  425. if formpermessodaaggiungere.is_valid():
  426. print('formpermessodaaggiungere è valido')
  427. print("cazzo cazzo")
  428. else:
  429. print('errore',formpermessodaaggiungere)
  430. #formpermessoupdate = form.PermessoUpdate(request.POST)
  431. return render(request,'amministratore.edit.SEP.html',data)
  432. '''
  433. if 'ConfermaCancellazionePermessoXAmministratore' in request.POST:
  434. print("Premuto tasto ConfermaCancellazionePermessoXAmministratore")
  435. formcancellapermessoxamministratore = FormCancellaPermessiXAmministratore(request.POST)
  436. if formcancellapermessoxamministratore.is_valid():
  437. print('Form Valida CancellaPermessoXAmministratore')
  438. permessodarimuovere = formcancellapermessoxamministratore.cleaned_data.get('ConfermaCancellazionePermessoXAmministratore')
  439. print('Permesso da rimuovere',permessodarimuovere)
  440. amp = AMP.objects.get(pk=permessodarimuovere)
  441. amp.delete()
  442. if 'PermessoDaAggiungereButton' in request.POST:
  443. print("Premuto aggiunta permesso")
  444. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST)
  445. print(formpermessodaaggiungere)
  446. if formpermessodaaggiungere.is_valid():
  447. print("Form permessodaaggiungere valida")
  448. pda = Permesso.objects.get(pk=formpermessodaaggiungere.cleaned_data.get('permessodaaggiungere'))
  449. print('pda',pda.nome)
  450. amp = AMP()
  451. amp.amministratore = amministratore
  452. amp.permesso = pda
  453. amp.save()
  454. data['pane']='Permesso'
  455. if 'AziendaConfermaCancellazionePermesso' in request.POST:
  456. formcancellapermesso = FormCancellaPermessi(request.POST)
  457. if formcancellapermesso.is_valid():
  458. print('form valida formcancellapermesso')
  459. aziendadarimuovere = formcancellapermesso.cleaned_data.get('ConfermaCancellazionePermesso')
  460. print('azienda da rimuovere',aziendadarimuovere)
  461. #prima cosa togliamo i diritti alle sedi
  462. aztorm = None
  463. try:
  464. aztorm = Azienda.objects.get(pk=aziendadarimuovere)
  465. except Azienda.DoesNotExist:
  466. print('Azienda non trovata',aziendadarimuovere)
  467. print('azienda trovata',aztorm.nome)
  468. print("Iniziamo dalle sedi")
  469. sedi = aztorm.sede_set.all()
  470. for tmp in sedi:
  471. print('sede',tmp.nome)
  472. for p in tmp.sep_set.all():
  473. print('permesso',p.permesso.nome)
  474. p.delete()
  475. print("Ora tocca all'azienda")
  476. for p in aztorm.azp_set.all():
  477. print('permesso azienda',p.permesso.nome)
  478. p.delete()
  479. data['pane'] = "Azienda"
  480. listaaziendatutte = Azienda.objects.all()
  481. if amministratore.id:
  482. data['listaazienda'] = listaAZP(amministratore)[0]
  483. data['listaaziendadiff'] = list(set(listaaziendatutte)-set(data['listaazienda']))
  484. else:
  485. data['listaaziendadiff'] = list(set(listaaziendatutte))
  486. if 'AziendaDaAggiungereButton' in request.POST:
  487. formaziendamancante=FormAziendaMancante(request.POST)
  488. formaziendamancante.c(data['listaaziendadiff'])
  489. #print('fam',formaziendamancante)
  490. if formaziendamancante.is_valid():
  491. print('form valida formaziendamancante')
  492. aziendadaaggiungere = formaziendamancante.cleaned_data.get('aziendadaaggiungere')
  493. print('Azienda da aggiungere',aziendadaaggiungere)
  494. aztoadd = None
  495. try:
  496. aztoadd = Azienda.objects.get(pk=aziendadaaggiungere)
  497. except Azienda.DoesNotExist as dne:
  498. print("Azienda non trovata",aziendadaaggiungere)
  499. if aztoadd:
  500. print('Azienda in corso di aggiunta',aztoadd.nome)
  501. azp = AZP()
  502. azp.azienda = aztoadd
  503. azp.amministratore = amministratore
  504. azp.permesso = getPermesso("AZIENDA")
  505. print('permesso base',getPermesso("AZIENDA").nome)
  506. azp.save()
  507. print(azp.id)
  508. data['pane']='Azienda'
  509. if 'AziendaSelect' in request.POST:
  510. print('Richiesta Selezione Azienda')
  511. formaziendaselect = FormAziendaSelect(request.POST)
  512. if formaziendaselect.is_valid():
  513. print('FormAziendaSelect valido')
  514. aziendaselect = formaziendaselect.cleaned_data.get('AziendaSelect')
  515. request.session['aziendaselect'] = aziendaselect
  516. print('aziendaselect',aziendaselect)
  517. # una volta ottenuta l'azienda, selezioniamo le sedi:
  518. # le selezioni sono due:
  519. # 1 lista delle sedi gia' associate all'utente attraverso il permesso(SEP)
  520. # 2 lista delle sedi ancora da assegnare (tolte le sedi gia' assegnate)
  521. data['listasede'] = listaSEP(aziendaselect,amministratore)[0]
  522. data['listasedediff']= list(set(Azienda.objects.get(pk=aziendaselect).sede_set.all()) - set(listaSEP(aziendaselect,amministratore)[0]))
  523. print("lista sede",len(data['listasede']))
  524. data['pane']='Azienda'
  525. if 'SedeConfermaCancellazionePermesso' in request.POST:
  526. print('Richiesta cancellazione Permessi Sede')
  527. if 'SedeDaAggiungereButton' in request.POST:
  528. if 'aziendaselect' in request.session:
  529. aziendaselect = request.session.get('aziendaselect')
  530. print('Richiesta Sede da aggiungere')
  531. data['listasede'] = listaSEP(aziendaselect,amministratore)[0]
  532. data['listasedediff']= list(set(Azienda.objects.get(pk=aziendaselect).sede_set.all()) - set(listaSEP(aziendaselect,amministratore)[0]))
  533. print('listasedediff len',len(data['listasedediff']))
  534. formsedemancante = FormSedeMancante(request.POST,lista=data['listasedediff'])
  535. #formsedemancante.c(data['listasedediff'])
  536. if 'ListaSedeMancante' in request.POST:
  537. print('ListaSedeMancante',request.POST['ListaSedeMancanteSelect'])
  538. if formsedemancante.is_valid():
  539. listasedemancante = formsedemancante.cleaned_data.get('ListaSedeMancanteSelect')
  540. print(listasedemancante)
  541. for lsm in listasedemancante:
  542. setSEP(Sede.objects.get(pk=lsm),amministratore,Permesso.objects.get(nome="SEDE"))
  543. #else: print(formsedemancante)
  544. '''
  545. ### editing amministratore senza ulteriori funzioni ###
  546. def editAmministratore(request):
  547. if not 'AdminId' in request.session:
  548. return HttpResponseRedirect(reverse("login:start"))
  549. ### funzioni esterne ###
  550. d = DataDict()
  551. data = d.getData()
  552. data['NavBar']=True
  553. data['ShowSelectAzienda'] = False
  554. data['ShowSelectSede'] = False
  555. define = Define(request)
  556. data['admin'] = define.getAdmin()
  557. data['azienda'] = define.getAzienda()
  558. data['AziendaId'] = define.getAziendaId()
  559. data['sede'] = define.getSede()
  560. data['SedeId'] = define.getSedeId()
  561. print('cazzo cazzo')
  562. ### funzioni esterne fine ###
  563. if 'AdminId' in request.session:
  564. data['AdminId'] = request.session['AdminId']
  565. admin = Amministratore.objects.get(pk=data['AdminId'])
  566. data['admin'] = admin
  567. print('admin',admin.id,admin.nome)
  568. data['permesso'] = getAMP(admin)[0]
  569. amministratore = data['admin']
  570. print('amministratore',amministratore.id,amministratore.nome)
  571. if request.method == 'POST':
  572. print("qualcosa e' stato premuto")
  573. if 'indietro' in request.POST:
  574. return HttpResponseRedirect(reverse("azienda:welcome"))
  575. if 'AmministratoreDirittiAziendaButton' in request.POST:
  576. print("premuto: 'AmministratoreDirittiAziendaButton'")
  577. return HttpResponseRedirect(reverse("amministratore:editAZP"))
  578. if 'AmministratoreUpdateButton' in request.POST:
  579. formamministratore = FormAmministratore(request.POST)
  580. if formamministratore.is_valid():
  581. print('form valida formamministratore')
  582. amministratore.login=formamministratore.cleaned_data.get('login')
  583. amministratore.nome=formamministratore.cleaned_data.get('nome')
  584. amministratore.mail=formamministratore.cleaned_data.get('mail')
  585. amministratore.pin=formamministratore.cleaned_data.get('pin')
  586. amministratore.save()
  587. print('id amministratore salvato/nuovo',amministratore.id,":",amministratore.nome)
  588. tmp = dict()
  589. tmp['nome'] = amministratore.nome
  590. tmp['login'] = amministratore.login
  591. tmp['pin'] = amministratore.pin
  592. tmp['mail'] = amministratore.mail
  593. data['amministratore'] = FormAmministratore(tmp)
  594. return render(request,'amministratore.edit.html',data)