views.py 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671
  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. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST)
  238. formpermessodaaggiungere.c(data['listapermessiassegnabili'])
  239. if formpermessodaaggiungere.is_valid():
  240. print('formpermessodaaggiungere valido')
  241. permesso = formpermessodaaggiungere.cleaned_data.get('ListaPermessiDaAggiungere')
  242. print('*' * 10)
  243. setAMP(amministratore,int(permesso))
  244. print('*' * 10)
  245. formpermessodarimuovere = FormPermessoDaRimuovere(request.POST)
  246. if formpermessodarimuovere.is_valid():
  247. print('formpermessodacancellare valido')
  248. permesso = formpermessodarimuovere.cleaned_data.get('ConfermaCancellazionePermesso')
  249. print('ConfermaCancellazionePermesso',permesso)
  250. delAMP(amministratore,permesso)
  251. data['listapermessiassegnati'] = getAMP(data['amministratore'])[1]
  252. print('listapermessiassegnati',data['listapermessiassegnati'])
  253. data['listapermessiassegnabili'] = Permesso.objects.all()
  254. print('listapermessiassegnabili',data['listapermessiassegnabili'])
  255. return render(request,'amministratore.edit.AMP.html',data)
  256. def editAZP(request):
  257. ### edit diritti associati all'azienda.
  258. ### in questa sezione procediamo con l'assegnare o rimuovere i diritti di questo amministratore
  259. ### per le aziende in elenco.
  260. if not 'AdminId' in request.session:
  261. return HttpResponseRedirect(reverse("login:start"))
  262. ### funzioni esterne ###
  263. d = DataDict()
  264. data = d.getData()
  265. data['NavBar']=True
  266. data['ShowSelectAzienda'] = False
  267. data['ShowSelectSede'] = False
  268. define = Define(request)
  269. data['admin'] = define.getAdmin()
  270. data['azienda'] = define.getAzienda()
  271. data['AziendaId'] = define.getAziendaId()
  272. data['sede'] = define.getSede()
  273. data['SedeId'] = define.getSedeId()
  274. ### funzioni esterne fine ###
  275. if 'AdminId' in request.session:
  276. data['AdminId'] = request.session['AdminId']
  277. admin = Amministratore.objects.get(pk=data['AdminId'])
  278. data['admin'] = admin
  279. print('admin',admin.id,admin.nome)
  280. data['permesso'] = getAMP(admin)[0]
  281. listaaziendatutte = Azienda.objects.all()
  282. amministratore = None
  283. if 'AmministratoreEditId' in request.session:
  284. amministratoreEditId = request.session.get('AmministratoreEditId')
  285. try:
  286. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  287. except Amministratore.DoesNotExist as dne:
  288. return HttpResponseRedirect(reverse("amministratore:edit"))
  289. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  290. data['amministratore'] = amministratore
  291. if amministratore:
  292. data['listaazienda'] = listaAZP(amministratore)[0]
  293. data['listaaziendadiff'] = list(set(listaaziendatutte)-set(data['listaazienda']))
  294. else:
  295. data['listaaziendadiff'] = list(set(listaaziendatutte))
  296. #parliamo di diritti assegnati all'azienda.
  297. data['dirittiAZIENDA'] = Permesso.objects.filter(Q(classe='AZI')|Q(classe='SED'))
  298. print('dirittiAZIENDA',len(data['dirittiAZIENDA']))
  299. if request.method == 'POST':
  300. print("qualcosa e' stato premuto")
  301. if 'AmministratoreReturnButton' in request.POST:
  302. print("Un tasto è stato premuto 'AmministratoreReturnButton'")
  303. return HttpResponseRedirect(reverse("amministratore:welcome"))
  304. if 'AmministratoreButton' in request.POST:
  305. print("Un tasto è stato premuto 'AmministratoreButton'")
  306. return HttpResponseRedirect(reverse("amministratore:edit"))
  307. if 'AziendaDaAggiungereButton' in request.POST:
  308. print('un tasto è stato premuto AziendaDaAggiungereButton')
  309. formaziendadaaggiungere = FormAziendaDaAggiungere(request.POST,azienda=listaaziendatutte)
  310. if formaziendadaaggiungere.is_valid():
  311. print('AziendaDaAggiungere, form valida')
  312. azienda = formaziendadaaggiungere.cleaned_data.get('ListaAziendaDaAggiungere')
  313. print(azienda)
  314. setAZP(azienda,amministratore,'AZIENDA')
  315. else:
  316. print('AziendaDaAggiungere, form non valido')
  317. if 'SedeButton' in request.POST:
  318. print("Un tasto è stato premuto 'SedeButton'")
  319. azienda = request.POST.get('SedeButton')
  320. request.session['EditAziendaId'] = azienda
  321. return HttpResponseRedirect(reverse("amministratore:editSEP"))
  322. if 'AziendaPermessoUpdateButton' in request.POST:
  323. print("Un tasto è stato premuto 'AziendaPermessoUpdate'")
  324. print(request.POST)
  325. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST)
  326. formpermessodaaggiungere.c(Permesso.objects.filter(classe="SED"))
  327. if formpermessodaaggiungere.is_valid():
  328. print('formpermessodaaggiungere è valido')
  329. print("cazzo cazzo")
  330. else:
  331. print('errore',formpermessodaaggiungere)
  332. #formpermessoupdate = form.PermessoUpdate(request.POST)
  333. if amministratore:
  334. data['listaazienda'] = listaAZP(amministratore)[0]
  335. data['listaaziendadiff'] = list(set(listaaziendatutte)-set(data['listaazienda']))
  336. else:
  337. data['listaaziendadiff'] = list(set(listaaziendatutte))
  338. return render(request,'amministratore.edit.AZP.html',data)
  339. def editSEP(request):
  340. ### edit diritti associati alla sede
  341. ### in questa sezione procediamo con l'assegnare o rimuovere i diritti di questo amministratore
  342. ### per le sedi in elenco.
  343. if not 'AdminId' in request.session:
  344. return HttpResponseRedirect(reverse("login:start"))
  345. ### funzioni esterne ###
  346. d = DataDict()
  347. data = d.getData()
  348. data['NavBar']=True
  349. data['ShowSelectAzienda'] = False
  350. data['ShowSelectSede'] = False
  351. define = Define(request)
  352. data['admin'] = define.getAdmin()
  353. data['azienda'] = define.getAzienda()
  354. data['AziendaId'] = define.getAziendaId()
  355. data['sede'] = define.getSede()
  356. data['SedeId'] = define.getSedeId()
  357. ### funzioni esterne fine ###
  358. if not 'EditAziendaId' in request.session:
  359. HttpResponseRedirect(reverse("amministratore:editAZP"))
  360. if 'AdminId' in request.session:
  361. data['AdminId'] = request.session['AdminId']
  362. admin = Amministratore.objects.get(pk=data['AdminId'])
  363. data['admin'] = admin
  364. print('admin',admin.id,admin.nome)
  365. data['permesso'] = getAMP(admin)[0]
  366. amministratore = None
  367. if 'AmministratoreEditId' in request.session:
  368. amministratoreEditId = request.session.get('AmministratoreEditId')
  369. try:
  370. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  371. except Amministratore.DoesNotExist as dne:
  372. return HttpResponseRedirect(reverse("amministratore:editSEP"))
  373. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  374. data['amministratore'] = amministratore
  375. azienda = Azienda.objects.get(pk=request.session.get('EditAziendaId'))
  376. print('azienda',azienda.nome)
  377. data['aziendaOnWork'] = azienda
  378. data['listasede'] = listaSEP(azienda,amministratore.id,"SEDE")[0]
  379. print("data['listasede']",len(data['listasede']))
  380. listasedetutte = azienda.sede_set.all()
  381. print('listasedetutte',len(listasedetutte))
  382. data['listasedediff'] = list(set(listasedetutte)-set(data['listasede']))
  383. #data['listasedediff'] = listasedetutte
  384. print("data['listasedediff']",len(data['listasedediff']))
  385. # parliamo di diritti relativi alle sedi
  386. data['dirittiSEDE'] = Permesso.objects.filter(classe='SED')
  387. print('dirittiSEDE',len(data['dirittiSEDE']))
  388. print('minchia')
  389. if request.method == 'POST':
  390. print("qualcosa e' stato premuto")
  391. if 'AmministratoreReturnButton' in request.POST:
  392. print("Un tasto è stato premuto 'AmministratoreReturnButton'")
  393. return HttpResponseRedirect(reverse("amministratore:welcome"))
  394. if 'AmministratoreButton' in request.POST:
  395. print("Un tasto è stato premuto 'AmministratoreButton'")
  396. return HttpResponseRedirect(reverse("amministratore:edit"))
  397. return render(request,'amministratore.edit.SEP.html',data)
  398. '''
  399. if 'ConfermaCancellazionePermessoXAmministratore' in request.POST:
  400. print("Premuto tasto ConfermaCancellazionePermessoXAmministratore")
  401. formcancellapermessoxamministratore = FormCancellaPermessiXAmministratore(request.POST)
  402. if formcancellapermessoxamministratore.is_valid():
  403. print('Form Valida CancellaPermessoXAmministratore')
  404. permessodarimuovere = formcancellapermessoxamministratore.cleaned_data.get('ConfermaCancellazionePermessoXAmministratore')
  405. print('Permesso da rimuovere',permessodarimuovere)
  406. amp = AMP.objects.get(pk=permessodarimuovere)
  407. amp.delete()
  408. if 'PermessoDaAggiungereButton' in request.POST:
  409. print("Premuto aggiunta permesso")
  410. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST)
  411. print(formpermessodaaggiungere)
  412. if formpermessodaaggiungere.is_valid():
  413. print("Form permessodaaggiungere valida")
  414. pda = Permesso.objects.get(pk=formpermessodaaggiungere.cleaned_data.get('permessodaaggiungere'))
  415. print('pda',pda.nome)
  416. amp = AMP()
  417. amp.amministratore = amministratore
  418. amp.permesso = pda
  419. amp.save()
  420. data['pane']='Permesso'
  421. if 'AziendaConfermaCancellazionePermesso' in request.POST:
  422. formcancellapermesso = FormCancellaPermessi(request.POST)
  423. if formcancellapermesso.is_valid():
  424. print('form valida formcancellapermesso')
  425. aziendadarimuovere = formcancellapermesso.cleaned_data.get('ConfermaCancellazionePermesso')
  426. print('azienda da rimuovere',aziendadarimuovere)
  427. #prima cosa togliamo i diritti alle sedi
  428. aztorm = None
  429. try:
  430. aztorm = Azienda.objects.get(pk=aziendadarimuovere)
  431. except Azienda.DoesNotExist:
  432. print('Azienda non trovata',aziendadarimuovere)
  433. print('azienda trovata',aztorm.nome)
  434. print("Iniziamo dalle sedi")
  435. sedi = aztorm.sede_set.all()
  436. for tmp in sedi:
  437. print('sede',tmp.nome)
  438. for p in tmp.sep_set.all():
  439. print('permesso',p.permesso.nome)
  440. p.delete()
  441. print("Ora tocca all'azienda")
  442. for p in aztorm.azp_set.all():
  443. print('permesso azienda',p.permesso.nome)
  444. p.delete()
  445. data['pane'] = "Azienda"
  446. listaaziendatutte = Azienda.objects.all()
  447. if amministratore.id:
  448. data['listaazienda'] = listaAZP(amministratore)[0]
  449. data['listaaziendadiff'] = list(set(listaaziendatutte)-set(data['listaazienda']))
  450. else:
  451. data['listaaziendadiff'] = list(set(listaaziendatutte))
  452. if 'AziendaDaAggiungereButton' in request.POST:
  453. formaziendamancante=FormAziendaMancante(request.POST)
  454. formaziendamancante.c(data['listaaziendadiff'])
  455. #print('fam',formaziendamancante)
  456. if formaziendamancante.is_valid():
  457. print('form valida formaziendamancante')
  458. aziendadaaggiungere = formaziendamancante.cleaned_data.get('aziendadaaggiungere')
  459. print('Azienda da aggiungere',aziendadaaggiungere)
  460. aztoadd = None
  461. try:
  462. aztoadd = Azienda.objects.get(pk=aziendadaaggiungere)
  463. except Azienda.DoesNotExist as dne:
  464. print("Azienda non trovata",aziendadaaggiungere)
  465. if aztoadd:
  466. print('Azienda in corso di aggiunta',aztoadd.nome)
  467. azp = AZP()
  468. azp.azienda = aztoadd
  469. azp.amministratore = amministratore
  470. azp.permesso = getPermesso("AZIENDA")
  471. print('permesso base',getPermesso("AZIENDA").nome)
  472. azp.save()
  473. print(azp.id)
  474. data['pane']='Azienda'
  475. if 'AziendaSelect' in request.POST:
  476. print('Richiesta Selezione Azienda')
  477. formaziendaselect = FormAziendaSelect(request.POST)
  478. if formaziendaselect.is_valid():
  479. print('FormAziendaSelect valido')
  480. aziendaselect = formaziendaselect.cleaned_data.get('AziendaSelect')
  481. request.session['aziendaselect'] = aziendaselect
  482. print('aziendaselect',aziendaselect)
  483. # una volta ottenuta l'azienda, selezioniamo le sedi:
  484. # le selezioni sono due:
  485. # 1 lista delle sedi gia' associate all'utente attraverso il permesso(SEP)
  486. # 2 lista delle sedi ancora da assegnare (tolte le sedi gia' assegnate)
  487. data['listasede'] = listaSEP(aziendaselect,amministratore)[0]
  488. data['listasedediff']= list(set(Azienda.objects.get(pk=aziendaselect).sede_set.all()) - set(listaSEP(aziendaselect,amministratore)[0]))
  489. print("lista sede",len(data['listasede']))
  490. data['pane']='Azienda'
  491. if 'SedeConfermaCancellazionePermesso' in request.POST:
  492. print('Richiesta cancellazione Permessi Sede')
  493. if 'SedeDaAggiungereButton' in request.POST:
  494. if 'aziendaselect' in request.session:
  495. aziendaselect = request.session.get('aziendaselect')
  496. print('Richiesta Sede da aggiungere')
  497. data['listasede'] = listaSEP(aziendaselect,amministratore)[0]
  498. data['listasedediff']= list(set(Azienda.objects.get(pk=aziendaselect).sede_set.all()) - set(listaSEP(aziendaselect,amministratore)[0]))
  499. print('listasedediff len',len(data['listasedediff']))
  500. formsedemancante = FormSedeMancante(request.POST,lista=data['listasedediff'])
  501. #formsedemancante.c(data['listasedediff'])
  502. if 'ListaSedeMancante' in request.POST:
  503. print('ListaSedeMancante',request.POST['ListaSedeMancanteSelect'])
  504. if formsedemancante.is_valid():
  505. listasedemancante = formsedemancante.cleaned_data.get('ListaSedeMancanteSelect')
  506. print(listasedemancante)
  507. for lsm in listasedemancante:
  508. setSEP(Sede.objects.get(pk=lsm),amministratore,Permesso.objects.get(nome="SEDE"))
  509. #else: print(formsedemancante)
  510. '''
  511. ### editing amministratore senza ulteriori funzioni ###
  512. def editAmministratore(request):
  513. if not 'AdminId' in request.session:
  514. return HttpResponseRedirect(reverse("login:start"))
  515. ### funzioni esterne ###
  516. d = DataDict()
  517. data = d.getData()
  518. data['NavBar']=True
  519. data['ShowSelectAzienda'] = False
  520. data['ShowSelectSede'] = False
  521. define = Define(request)
  522. data['admin'] = define.getAdmin()
  523. data['azienda'] = define.getAzienda()
  524. data['AziendaId'] = define.getAziendaId()
  525. data['sede'] = define.getSede()
  526. data['SedeId'] = define.getSedeId()
  527. print('cazzo cazzo')
  528. ### funzioni esterne fine ###
  529. if 'AdminId' in request.session:
  530. data['AdminId'] = request.session['AdminId']
  531. admin = Amministratore.objects.get(pk=data['AdminId'])
  532. data['admin'] = admin
  533. print('admin',admin.id,admin.nome)
  534. data['permesso'] = getAMP(admin)[0]
  535. amministratore = data['admin']
  536. print('amministratore',amministratore.id,amministratore.nome)
  537. if request.method == 'POST':
  538. print("qualcosa e' stato premuto")
  539. if 'indietro' in request.POST:
  540. return HttpResponseRedirect(reverse("azienda:welcome"))
  541. if 'AmministratoreDirittiAziendaButton' in request.POST:
  542. print("premuto: 'AmministratoreDirittiAziendaButton'")
  543. return HttpResponseRedirect(reverse("amministratore:editAZP"))
  544. if 'AmministratoreUpdateButton' in request.POST:
  545. formamministratore = FormAmministratore(request.POST)
  546. if formamministratore.is_valid():
  547. print('form valida formamministratore')
  548. amministratore.login=formamministratore.cleaned_data.get('login')
  549. amministratore.nome=formamministratore.cleaned_data.get('nome')
  550. amministratore.mail=formamministratore.cleaned_data.get('mail')
  551. amministratore.pin=formamministratore.cleaned_data.get('pin')
  552. amministratore.save()
  553. print('id amministratore salvato/nuovo',amministratore.id,":",amministratore.nome)
  554. tmp = dict()
  555. tmp['nome'] = amministratore.nome
  556. tmp['login'] = amministratore.login
  557. tmp['pin'] = amministratore.pin
  558. tmp['mail'] = amministratore.mail
  559. data['amministratore'] = FormAmministratore(tmp)
  560. return render(request,'amministratore.edit.html',data)