views.py 39 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015
  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'])[0]:
  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. request.session['masteramm'] = True
  79. print('masteramm in edit adm',request.session['masteramm'])
  80. return HttpResponseRedirect(reverse('amministratore:edit'))
  81. formamministratoreeditid = FormAmministratoreEditId(request.POST,amministratore=data['amministratorelista'])
  82. if formamministratoreeditid.is_valid():
  83. scelta = formamministratoreeditid.cleaned_data.get('scelta')
  84. request.session['AmministratoreEditId'] = scelta
  85. print("Scelta effettuata",scelta)
  86. request.session['masteramm'] = True
  87. print('masteramm in edit adm',request.session['masteramm'])
  88. return HttpResponseRedirect(reverse("amministratore:edit"))
  89. #data['amministratorelista'] = amministratorelista
  90. #data['numeroRecordAmministratore'] = len(amministratorelista)
  91. #print(data)
  92. return render(request,'amministratore.welcome.html',data)
  93. def edit(request):
  94. '''
  95. edit amministratore o simile
  96. sulla base dei diritti assegnati, puo' leggero e/o scrivere nell'utente
  97. nella sede o nell'azienda.
  98. i diritti sono assegnati sulla base dell'utente e non successivamente
  99. all'assegnazione, tanto se l'utente ha una zona assegnata, quella puo' vedere
  100. e basta.
  101. '''
  102. if not 'AdminId' in request.session:
  103. return HttpResponseRedirect(reverse("login:start"))
  104. data = dict()
  105. data['HeaderTitle'] = getConfig('HeaderTitle')
  106. data['Navbar']=False
  107. if 'AdminId' in request.session:
  108. data['AdminId'] = request.session['AdminId']
  109. admin = Amministratore.objects.get(pk=data['AdminId'])
  110. data['admin'] = admin
  111. print('admin',admin.id,admin.nome)
  112. data['permesso'] = getAMP(admin)[0]
  113. azienda = None
  114. if 'AziendaId' in request.session:
  115. AziendaId = request.session['AziendaId']
  116. print('AziendaId',AziendaId)
  117. azienda = Azienda.objects.get(pk=AziendaId)
  118. data['azienda'] = azienda
  119. sede = None
  120. if 'SedeId' in request.session:
  121. SedeId = request.session['SedeId']
  122. print('SedeId',SedeId)
  123. try:
  124. sede = Sede.objects.get(pk=SedeId)
  125. except Sede.DoesNotExist as dne:
  126. print("Sede non esiste")
  127. data['sede'] = sede
  128. amministratore = None
  129. print(request)
  130. if 'AmministratoreEditId' in request.session:
  131. amministratoreEditId = request.session.get('AmministratoreEditId')
  132. try:
  133. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  134. except Amministratore.DoesNotExist as dne:
  135. amministratore = Amministratore()
  136. amministratore.pin = str(randint(100000,999999))
  137. print('amministratore',amministratore.id,amministratore.nome)
  138. print("request.method",request.method)
  139. if 'masteramm' in request.session:
  140. print('masteramm',request.session['masteramm'])
  141. data['MASTERAMM'] = request.session['masteramm']
  142. if request.method == 'POST':
  143. print("qualcosa e' stato premuto")
  144. if 'indietro' in request.POST:
  145. return HttpResponseRedirect(reverse("amministratore:welcome"))
  146. if 'AmministratoreDirittiAmministratoreButton' in request.POST:
  147. print("Un tasto è stato premuto 'AmministratoreDirittiAmministratoreButton'")
  148. return HttpResponseRedirect(reverse("amministratore:editAMP"))
  149. if 'AmministratoreCancellaButton' in request.POST:
  150. print('editAmministratore: premuto "AmministratoreCancellaButton"')
  151. amp = amministratore.amp_set.all()
  152. azp = amministratore.azp_set.all()
  153. sep = amministratore.sep_set.all()
  154. print(amministratore.nome)
  155. print(len(amp),amp)
  156. print(len(azp),azp)
  157. print(len(sep),sep)
  158. for x in sep:
  159. x.delete()
  160. for x in azp:
  161. x.delete()
  162. for x in amp:
  163. x.delete()
  164. amministratore.delete()
  165. return HttpResponseRedirect(reverse("amministratore:welcome"))
  166. if 'AmministratoreDirittiAziendaButton' in request.POST:
  167. print('edit azienda: premuto "AmministratoreDirittiAziendaButton"')
  168. return HttpResponseRedirect(reverse("amministratore:editAZ"))
  169. if 'AmministratoreUpdateButton' in request.POST:
  170. formamministratore = FormAmministratore(request.POST)
  171. if formamministratore.is_valid():
  172. print('form valida formamministratore')
  173. amministratore.login=formamministratore.cleaned_data.get('login')
  174. amministratore.nome=formamministratore.cleaned_data.get('nome')
  175. amministratore.mail=formamministratore.cleaned_data.get('mail')
  176. amministratore.pin=formamministratore.cleaned_data.get('pin')
  177. amministratore.save()
  178. print('id amministratore salvato/nuovo',amministratore.id,":",amministratore.nome)
  179. request.session['AmministratoreEditId'] = amministratore.id
  180. return HttpResponseRedirect(reverse('amministratore:welcome'))
  181. tmp = dict()
  182. tmp['nome'] = amministratore.nome
  183. tmp['login'] = amministratore.login
  184. tmp['pin'] = amministratore.pin
  185. tmp['mail'] = amministratore.mail
  186. data['amministratore'] = FormAmministratore(tmp)
  187. if amministratore.id:
  188. # elenco aziende autorizzate per amministratore
  189. data['listaazienda'] = listaAZP(amministratore)[0]
  190. print('lista azienda',len(data['listaazienda']))
  191. # elenco dei permessi per amministratore
  192. data['listapermesso'] = getAMP(amministratore)[2]
  193. print('lista permesso',len(data['listapermesso']))
  194. #calcola la differenza tra i permessi assegnati e quelli disponibili
  195. data['listapermessotutto'] = getPermesso()
  196. data['listapermessomancante'] = getAMP(amministratore)[1]
  197. data['listapermessodiff'] = list(set(data['listapermessotutto']) - set(data['listapermessomancante']))
  198. print('Quanti ne mancano',len(data['listapermessodiff']),data['listapermessodiff'])
  199. #calcolo la differenza tra tutte le aziende e le aziende sottoposte a permesso
  200. listaaziendatutte = Azienda.objects.all()
  201. data['listaaziendadiff'] = list(set(listaaziendatutte)-set(data['listaazienda']))
  202. print('Differenza aziende',len(data['listaaziendadiff']))
  203. return render(request,'amministratore.edit.html',data)
  204. def editAMP(request):
  205. ### consente di aggiornare i diritti a livello di amministratore ###
  206. if not 'AdminId' in request.session:
  207. return HttpResponseRedirect(reverse("login:start"))
  208. ### funzioni esterne ###
  209. d = DataDict()
  210. data = d.getData()
  211. data['NavBar']=True
  212. data['ShowSelectAzienda'] = False
  213. data['ShowSelectSede'] = False
  214. define = Define(request)
  215. data['admin'] = define.getAdmin()
  216. data['azienda'] = define.getAzienda()
  217. data['AziendaId'] = define.getAziendaId()
  218. data['sede'] = define.getSede()
  219. data['SedeId'] = define.getSedeId()
  220. ### funzioni esterne fine ###
  221. if 'AdminId' in request.session:
  222. data['AdminId'] = request.session['AdminId']
  223. admin = Amministratore.objects.get(pk=data['AdminId'])
  224. data['admin'] = admin
  225. print('admin',admin.id,admin.nome)
  226. data['permesso'] = getAMP(admin)[0]
  227. amministratore = None
  228. if 'AmministratoreEditId' in request.session:
  229. amministratoreEditId = request.session.get('AmministratoreEditId')
  230. try:
  231. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  232. except Amministratore.DoesNotExist as dne:
  233. return HttpResponseRedirect(reverse("amministratore:edit"))
  234. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  235. data['amministratore'] = amministratore
  236. data['listapermessiassegnati'] = getAMP(data['amministratore'])[1]
  237. print('listapermessiassegnati',data['listapermessiassegnati'])
  238. data['listapermessiassegnabili'] = Permesso.objects.all()
  239. print('listapermessiassegnabili',data['listapermessiassegnabili'])
  240. if request.method == 'POST':
  241. if 'AmministratoreButton' in request.POST:
  242. print("Un tasto è stato premuto 'AmministratoreButton'")
  243. return HttpResponseRedirect(reverse("amministratore:edit"))
  244. if 'AmministratoreReturnButton' in request.POST:
  245. print("Un tasto èstato premuto 'AmministratoreReturnButton'")
  246. return HttpResponseRedirect(reverse("amministratore:welcome"))
  247. if 'indietro' in request.POST:
  248. print("Un tasto è stato premuto 'Indietro'")
  249. return HttpResponseRedirect(reverse("azienda:welcome"))
  250. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST,permessi=data['listapermessiassegnabili'])
  251. if formpermessodaaggiungere.is_valid():
  252. print('formpermessodaaggiungere valido')
  253. permesso = formpermessodaaggiungere.cleaned_data.get('ListaPermessiDaAggiungere')
  254. print('*' * 10)
  255. setAMP(amministratore,int(permesso))
  256. print('*' * 10)
  257. else:
  258. print('non va: formpermessodaaggiungere',formpermessodaaggiungere)
  259. print('*' * 20)
  260. formpermessodarimuovere = FormPermessoDaRimuovere(request.POST)
  261. if formpermessodarimuovere.is_valid():
  262. print('formpermessodarimuovere valido')
  263. permesso = formpermessodarimuovere.cleaned_data.get('ConfermaCancellazionePermesso')
  264. print('ConfermaCancellazionePermesso',permesso)
  265. delAMP(amministratore,permesso)
  266. else:
  267. print('non va: formpermessodarimuovere',formpermessodarimuovere)
  268. else:
  269. print('che merda do operazione')
  270. print(request.POST)
  271. data['listapermessiassegnati'] = getAMP(data['amministratore'])[1]
  272. print('listapermessiassegnati',data['listapermessiassegnati'])
  273. data['listapermessiassegnabili'] = Permesso.objects.all()
  274. print('listapermessiassegnabili',data['listapermessiassegnabili'])
  275. return render(request,'amministratore.edit.AMP.html',data)
  276. def editAZ(request):
  277. ### edit lista aziende autorizzate
  278. if not 'AdminId' in request.session:
  279. return HttpResponseRedirect(reverse("login:start"))
  280. ### funzioni esterne ###
  281. d = DataDict()
  282. data = d.getData()
  283. data['NavBar']=True
  284. data['ShowSelectAzienda'] = False
  285. data['ShowSelectSede'] = False
  286. define = Define(request)
  287. data['admin'] = define.getAdmin()
  288. data['azienda'] = define.getAzienda()
  289. data['AziendaId'] = define.getAziendaId()
  290. data['sede'] = define.getSede()
  291. data['SedeId'] = define.getSedeId()
  292. ### funzioni esterne fine ###
  293. if 'AdminId' in request.session:
  294. data['AdminId'] = request.session['AdminId']
  295. admin = Amministratore.objects.get(pk=data['AdminId'])
  296. data['admin'] = admin
  297. print('admin',admin.id,admin.nome)
  298. data['permesso'] = getAMP(admin)[0]
  299. listaaziendatutte = Azienda.objects.all()
  300. if 'paramm' in request.session and request.session['paramm']:
  301. data['DONTSHOWDIRITTI']=True
  302. amministratore = None
  303. if 'AmministratoreEditId' in request.session:
  304. amministratoreEditId = request.session.get('AmministratoreEditId')
  305. try:
  306. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  307. except Amministratore.DoesNotExist as dne:
  308. return HttpResponseRedirect(reverse("amministratore:edit"))
  309. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  310. data['amministratore'] = amministratore
  311. if amministratore:
  312. data['listaazienda'] = listaAZP(amministratore)[0]
  313. data['listaaziendadiff'] = list(set(listaaziendatutte)-set(data['listaazienda']))
  314. else:
  315. data['listaaziendadiff'] = list(set(listaaziendatutte))
  316. #parliamo di diritti assegnati all'azienda.
  317. data['dirittiAZIENDA'] = Permesso.objects.filter(Q(classe='AZI')|Q(classe='SED'))
  318. print('dirittiAZIENDA',len(data['dirittiAZIENDA']))
  319. if request.method == 'POST':
  320. print("qualcosa e' stato premuto in editAZ")
  321. if 'AmministratoreReturnButton' in request.POST:
  322. print("Un tasto è stato premuto 'AmministratoreReturnButton'")
  323. return HttpResponseRedirect(reverse("amministratore:welcome"))
  324. if 'AmministratoreButton' in request.POST:
  325. print("Un tasto è stato premuto 'AmministratoreButton'")
  326. return HttpResponseRedirect(reverse("amministratore:edit"))
  327. if 'indietro' in request.POST:
  328. print("Un tasto è stato premuto 'Indietro'")
  329. return HttpResponseRedirect(reverse("azienda:welcome"))
  330. if 'AziendaDaAggiungereButton' in request.POST:
  331. print('un tasto è stato premuto AziendaDaAggiungereButton')
  332. formaziendadaaggiungere = FormAziendaDaAggiungere(request.POST,azienda=listaaziendatutte)
  333. if formaziendadaaggiungere.is_valid():
  334. print('AziendaDaAggiungere, form valida')
  335. azienda = formaziendadaaggiungere.cleaned_data.get('ListaAziendaDaAggiungere')
  336. print(azienda)
  337. setAZP(azienda,amministratore,'AZIENDA')
  338. else:
  339. print('AziendaDaAggiungere, form non valido')
  340. if 'SedeButton' in request.POST:
  341. print("Un tasto è stato premuto 'SedeButton'")
  342. azienda = request.POST.get('SedeButton')
  343. request.session['EditAziendaId'] = azienda
  344. return HttpResponseRedirect(reverse("amministratore:editSE"))
  345. if 'PermessoButton' in request.POST:
  346. print("Un tasto è stato premuto 'PermessoButton")
  347. azienda = request.POST.get('PermessoButton')
  348. request.session['EditAziendaPermessoId'] = azienda
  349. return HttpResponseRedirect(reverse("amministratore:editAZP"))
  350. if 'ConfermaCancellazioneAzienda' in request.POST:
  351. print("Un tasto è stato premuto 'ConfermaCancellazioneAzienda'")
  352. azi = int(request.POST.get('ConfermaCancellazioneAzienda'))
  353. delAZP(azi,amministratore)
  354. if amministratore:
  355. data['listaazienda'] = listaAZP(amministratore)[0]
  356. data['listaaziendadiff'] = list(set(listaaziendatutte)-set(data['listaazienda']))
  357. else:
  358. data['listaaziendadiff'] = list(set(listaaziendatutte))
  359. return render(request,'amministratore.edit.AZ.html',data)
  360. def editAZP(request):
  361. ### edit diritti associati all'azienda.
  362. ### in questa sezione procediamo con l'assegnare o rimuovere i diritti di questo amministratore
  363. ### per le aziende in elenco.
  364. if not 'AdminId' in request.session:
  365. return HttpResponseRedirect(reverse("login:start"))
  366. ### funzioni esterne ###
  367. d = DataDict()
  368. data = d.getData()
  369. data['NavBar']=True
  370. data['ShowSelectAzienda'] = False
  371. data['ShowSelectSede'] = False
  372. define = Define(request)
  373. data['admin'] = define.getAdmin()
  374. data['azienda'] = define.getAzienda()
  375. data['AziendaId'] = define.getAziendaId()
  376. data['sede'] = define.getSede()
  377. data['SedeId'] = define.getSedeId()
  378. ### funzioni esterne fine ###
  379. if 'AdminId' in request.session:
  380. data['AdminId'] = request.session['AdminId']
  381. admin = Amministratore.objects.get(pk=data['AdminId'])
  382. data['admin'] = admin
  383. print('admin',admin.id,admin.nome)
  384. data['permessoAMP'] = getAMP(admin)[1]
  385. amministratore = None
  386. if 'AmministratoreEditId' in request.session:
  387. amministratoreEditId = request.session.get('AmministratoreEditId')
  388. try:
  389. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  390. except Amministratore.DoesNotExist as dne:
  391. return HttpResponseRedirect(reverse("amministratore:edit"))
  392. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  393. data['amministratore'] = amministratore
  394. if 'EditAziendaPermessoId' in request.session:
  395. azienda = Azienda.objects.get(pk=request.session.get('EditAziendaPermessoId'))
  396. print('azienda',azienda.nome)
  397. data['aziendaOnWork'] = azienda
  398. data['permessoAZP'] = getAZP(azienda,amministratore)[1]
  399. if 'paramm' in request.session and request.session['paramm']:
  400. data['DONTSHOWDIRITTI']=True
  401. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  402. data['amministratore'] = amministratore
  403. ####################################
  404. listadirittidisponibili= Permesso.objects.filter(Q(classe='AZI')|Q(classe='SED')|Q(classe='UTE')|Q(classe='DOC'))
  405. # diciamo che fatta cosi' mi pare una pecionata, ma funzionata. magari va ottimizzata un po'
  406. print(type(listadirittidisponibili))
  407. ldd = list()
  408. for i in listadirittidisponibili:
  409. ldd.append(i)
  410. print(type(ldd))
  411. print('*' * 20)
  412. data['listapermessiassegnabili'] = list()
  413. for i in ldd:
  414. if i not in data['permessoAZP']:
  415. data['listapermessiassegnabili'].append(i)
  416. ##########################################
  417. if request.method == 'POST':
  418. print("qualcosa e' stato premuto")
  419. if 'AmministratoreReturnButton' in request.POST:
  420. print("Un tasto è stato premuto 'AmministratoreReturnButton'")
  421. return HttpResponseRedirect(reverse("amministratore:welcome"))
  422. if 'AmministratoreButton' in request.POST:
  423. print("Un tasto è stato premuto 'AmministratoreButton'")
  424. return HttpResponseRedirect(reverse("amministratore:edit"))
  425. if 'AmministratoreAziendaButton' in request.POST:
  426. print("Un tasto è stato premuto 'AmministratoreAziendaButton'")
  427. return HttpResponseRedirect(reverse("amministratore:editAZ"))
  428. if 'PermessoDaAggiungereButton' in request.POST:
  429. print("Un tasto è stato premuto 'PermessoDaAggiungereButton'")
  430. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST,permessi=data['listapermessiassegnabili'])
  431. if formpermessodaaggiungere.is_valid():
  432. print('listapermessidaaggiungere',formpermessodaaggiungere.cleaned_data.get('ListaPermessiDaAggiungere'))
  433. setAZP(azienda,amministratore,int(formpermessodaaggiungere.cleaned_data.get('ListaPermessiDaAggiungere')))
  434. else:
  435. print('errore formpermessodaaggiungere',formpermessodaaggiungere)
  436. if 'indietro' in request.POST:
  437. print("Un tasto è stato premuto 'Indietro'")
  438. return HttpResponseRedirect(reverse("azienda:welcome"))
  439. if 'ConfermaCancellazionePermesso' in request.POST:
  440. print("Un tasto è stato premuto 'ConfermaCancellazionePermesso'")
  441. delAZP(azienda,amministratore,int(request.POST.get('ConfermaCancellazionePermesso')))
  442. data['permessoAZP'] = getAZP(azienda,amministratore)[1]
  443. ####################################
  444. listadirittidisponibili= Permesso.objects.filter(Q(classe='AZI')|Q(classe='SED')|Q(classe='UTE')|Q(classe='DOC'))
  445. # diciamo che fatta cosi' mi pare una pecionata, ma funzionata. magari va ottimizzata un po'
  446. print(type(listadirittidisponibili))
  447. ldd = list()
  448. for i in listadirittidisponibili:
  449. ldd.append(i)
  450. print(type(ldd))
  451. print('*' * 20)
  452. data['listapermessiassegnabili'] = list()
  453. for i in ldd:
  454. if i not in data['permessoAZP']:
  455. data['listapermessiassegnabili'].append(i)
  456. ##########################################
  457. return render(request,'amministratore.edit.AZP.html',data)
  458. def editSE(request):
  459. ### edit diritti associati alla sede
  460. ### in questa sezione procediamo con l'assegnare o rimuovere i diritti di questo amministratore
  461. ### per le sedi in elenco.
  462. if not 'AdminId' in request.session:
  463. return HttpResponseRedirect(reverse("login:start"))
  464. ### funzioni esterne ###
  465. d = DataDict()
  466. data = d.getData()
  467. data['NavBar']=True
  468. data['ShowSelectAzienda'] = False
  469. data['ShowSelectSede'] = False
  470. define = Define(request)
  471. data['admin'] = define.getAdmin()
  472. data['azienda'] = define.getAzienda()
  473. data['AziendaId'] = define.getAziendaId()
  474. data['sede'] = define.getSede()
  475. data['SedeId'] = define.getSedeId()
  476. ### funzioni esterne fine ###
  477. if not 'EditAziendaId' in request.session:
  478. HttpResponseRedirect(reverse("amministratore:editAZ"))
  479. if 'AdminId' in request.session:
  480. data['AdminId'] = request.session['AdminId']
  481. admin = Amministratore.objects.get(pk=data['AdminId'])
  482. data['admin'] = admin
  483. print('admin',admin.id,admin.nome)
  484. data['permesso'] = getAMP(admin)[0]
  485. amministratore = None
  486. if 'AmministratoreEditId' in request.session:
  487. amministratoreEditId = request.session.get('AmministratoreEditId')
  488. try:
  489. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  490. except Amministratore.DoesNotExist as dne:
  491. return HttpResponseRedirect(reverse("amministratore:editSE"))
  492. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  493. data['amministratore'] = amministratore
  494. azienda = Azienda.objects.get(pk=request.session.get('EditAziendaId'))
  495. print('azienda',azienda.nome)
  496. data['aziendaOnWork'] = azienda
  497. data['listasede'] = listaSEP(azienda,amministratore.id,"SEDE")[0]
  498. data['listasede'].sort(key=lambda x: x.nome,reverse=False)
  499. print("data['listasede']",len(data['listasede']),type(data['listasede']))
  500. listasedetutte = azienda.sede_set.all().order_by('nome')
  501. print('listasedetutte',len(listasedetutte))
  502. data['listasedediff'] = list(set(listasedetutte)-set(data['listasede']))
  503. data['listasedediff'].sort(key=lambda x: x.nome,reverse=False)
  504. #data['listasedediff'] = listasedetutte
  505. print("data['listasedediff']",len(data['listasedediff']))
  506. # parliamo di diritti relativi alle sedi
  507. data['dirittiSEDE'] = Permesso.objects.filter(classe='SED')
  508. print('dirittiSEDE',len(data['dirittiSEDE']))
  509. print('minchia')
  510. if request.method == 'POST':
  511. print("qualcosa é stato premuto")
  512. if 'AmministratoreReturnButton' in request.POST:
  513. print("Un tasto è stato premuto 'AmministratoreReturnButton'")
  514. return HttpResponseRedirect(reverse("amministratore:welcome"))
  515. if 'AmministratoreButton' in request.POST:
  516. print("Un tasto è stato premuto 'AmministratoreButton'")
  517. return HttpResponseRedirect(reverse("amministratore:edit"))
  518. if 'AmministratoreAziendaButton' in request.POST:
  519. print("Un tasto è stato premuto 'AmministratoreAziendaButton'")
  520. return HttpResponseRedirect(reverse("amministratore:editAZ"))
  521. if 'AmministratoreEditAZPButton' in request.POST:
  522. print("Un tasto è stato premuto 'AmministratoreEditAZPButton'")
  523. return HttpResponseRedirect(reverse("amministratore:editAZ"))
  524. if 'PermessoButton' in request.POST:
  525. print("Un tasto è stato premuto 'PermessoButton")
  526. sede = request.POST.get('PermessoButton')
  527. request.session['EditSedePermessoId'] = sede
  528. return HttpResponseRedirect(reverse("amministratore:editSEP"))
  529. if 'SedeConfermaCancellazionePermessoButton' in request.POST:
  530. print("un tasto è stato premuto 'SedeConfermaCancellazionePermessoButton'")
  531. sede = request.POST['SedeConfermaCancellazionePermessoButton']
  532. print('Sede da rimuovere',sede)
  533. p = Permesso.objects.get(nome="SEDE")
  534. lista = SEP.objects.filter(sede=sede,amministratore=amministratore,permesso=p)
  535. print('lista lista',lista)
  536. for p in lista:
  537. p.delete()
  538. p = Permesso.objects.get(nome="DOCUMENTO")
  539. lista = SEP.objects.filter(sede=sede,amministratore=amministratore,permesso=p)
  540. print('lista lista',lista)
  541. for p in lista:
  542. p.delete()
  543. p = Permesso.objects.get(nome="UTENTE")
  544. lista = SEP.objects.filter(sede=sede,amministratore=amministratore,permesso=p)
  545. print('lista lista',lista)
  546. for p in lista:
  547. p.delete()
  548. if 'SedeDaAggiungereButton' in request.POST:
  549. print('un tasto è stato premuto SedeDaAggiungereButton')
  550. formsededaaggiungere = FormSedeDaAggiungere(request.POST,sede=data['listasedediff'])
  551. if formsededaaggiungere.is_valid():
  552. print('SedeDaAggiungere, form valida')
  553. sede = formsededaaggiungere.cleaned_data.get('ListaSedeDaAggiungere')
  554. print('id sede da aggiungere',sede)
  555. setSEP(sede,amministratore,'SEDE')
  556. setSEP(sede,amministratore,'UTENTE')
  557. setSEP(sede,amministratore,'DOCUMENTO')
  558. else:
  559. print('SedeDaAggiungere, form non valido')
  560. if 'SedePermessoUpdateButton' in request.POST:
  561. print("Un tasto è stato premuto 'SedePermessoUpdate'")
  562. print(request.POST)
  563. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST)
  564. formpermessodaaggiungere.c(Permesso.objects.filter(classe="SED"))
  565. if formpermessodaaggiungere.is_valid():
  566. print('formpermessodaaggiungere è valido')
  567. print("cazzo cazzo")
  568. else:
  569. print('errore',formpermessodaaggiungere)
  570. #formpermessoupdate = form.PermessoUpdate(request.POST)
  571. data['listasede'] = listaSEP(azienda,amministratore.id,"SEDE")[0]
  572. data['listasede'].sort(key=lambda x: x.nome,reverse=False)
  573. print("data['listasede']",len(data['listasede']),type(data['listasede']))
  574. listasedetutte = azienda.sede_set.all().order_by('nome')
  575. print('listasedetutte',len(listasedetutte))
  576. data['listasedediff'] = list(set(listasedetutte)-set(data['listasede']))
  577. data['listasedediff'].sort(key=lambda x: x.nome,reverse=False)
  578. #data['listasedediff'] = listasedetutte
  579. print("data['listasedediff']",len(data['listasedediff']))
  580. # parliamo di diritti relativi alle sedi
  581. data['dirittiSEDE'] = Permesso.objects.filter(classe='SED')
  582. print('dirittiSEDE',len(data['dirittiSEDE']))
  583. return render(request,'amministratore.edit.SE.html',data)
  584. def editSEP(request):
  585. ### edit diritti associati all sede.
  586. ### in questa sezione procediamo con l'assegnare o rimuovere i diritti di questo amministratore
  587. ### per le aziende in elenco.
  588. if not 'AdminId' in request.session:
  589. return HttpResponseRedirect(reverse("login:start"))
  590. ### funzioni esterne ###
  591. d = DataDict()
  592. data = d.getData()
  593. data['NavBar']=True
  594. data['ShowSelectAzienda'] = False
  595. data['ShowSelectSede'] = False
  596. define = Define(request)
  597. data['admin'] = define.getAdmin()
  598. data['azienda'] = define.getAzienda()
  599. data['AziendaId'] = define.getAziendaId()
  600. data['sede'] = define.getSede()
  601. data['SedeId'] = define.getSedeId()
  602. ### funzioni esterne fine ###
  603. if 'AdminId' in request.session:
  604. data['AdminId'] = request.session['AdminId']
  605. admin = Amministratore.objects.get(pk=data['AdminId'])
  606. data['admin'] = admin
  607. print('admin',admin.id,admin.nome)
  608. data['permessoSEP'] = getAMP(admin)[1]
  609. amministratore = None
  610. if 'AmministratoreEditId' in request.session:
  611. amministratoreEditId = request.session.get('AmministratoreEditId')
  612. try:
  613. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  614. except Amministratore.DoesNotExist as dne:
  615. return HttpResponseRedirect(reverse("amministratore:edit"))
  616. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  617. data['amministratore'] = amministratore
  618. if 'EditSedePermessoId' in request.session:
  619. sede = Sede.objects.get(pk=request.session.get('EditSedePermessoId'))
  620. print('sede',sede.nome)
  621. data['sedeOnWork'] = sede
  622. data['permessoSEP'] = getSEP(sede,amministratore)[1]
  623. print('PermessoSEP',data['permessoSEP'])
  624. if 'paramm' in request.session and request.session['paramm']:
  625. data['DONTSHOWDIRITTI']=True
  626. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  627. data['amministratore'] = amministratore
  628. ####################################
  629. listadirittidisponibili= Permesso.objects.filter(Q(classe='SED')|Q(classe='UTE')|Q(classe='DOC'))
  630. # diciamo che fatta cosi' mi pare una pecionata, ma funzionata. magari va ottimizzata un po'
  631. print(type(listadirittidisponibili))
  632. ldd = list()
  633. for i in listadirittidisponibili:
  634. ldd.append(i)
  635. print(type(ldd))
  636. print('*' * 20)
  637. data['listapermessiassegnabili'] = list()
  638. for i in ldd:
  639. if i not in data['permessoSEP']:
  640. data['listapermessiassegnabili'].append(i)
  641. ##########################################
  642. if request.method == 'POST':
  643. print("qualcosa e' stato premuto")
  644. if 'AmministratoreReturnButton' in request.POST:
  645. print("Un tasto è stato premuto 'AmministratoreReturnButton'")
  646. return HttpResponseRedirect(reverse("amministratore:welcome"))
  647. if 'AmministratoreButton' in request.POST:
  648. print("Un tasto è stato premuto 'AmministratoreButton'")
  649. return HttpResponseRedirect(reverse("amministratore:edit"))
  650. if 'AmministratoreAziendaButton' in request.POST:
  651. print("Un tasto è stato premuto 'AmministratoreAziendeButton'")
  652. return HttpResponseRedirect(reverse("amministratore:editAZ"))
  653. if 'AmministratoreSedeButton' in request.POST:
  654. print("Un tasto è stato premuto 'AmministratoreAziendeButton'")
  655. return HttpResponseRedirect(reverse("amministratore:editSE"))
  656. if 'PermessoDaAggiungereButton' in request.POST:
  657. print("Un tasto è stato premuto 'PermessoDaAggiungereButton'")
  658. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST,permessi=data['listapermessiassegnabili'])
  659. if formpermessodaaggiungere.is_valid():
  660. print('listapermessidaaggiungere',formpermessodaaggiungere.cleaned_data.get('ListaPermessiDaAggiungere'))
  661. setSEP(sede,amministratore,int(formpermessodaaggiungere.cleaned_data.get('ListaPermessiDaAggiungere')))
  662. else:
  663. print('errore formpermessodaaggiungere',formpermessodaaggiungere)
  664. if 'ConfermaCancellazionePermesso' in request.POST:
  665. print("Un tasto è stato premuto 'ConfermaCancellazionePermesso'")
  666. delSEP(azienda,amministratore,int(request.POST.get('ConfermaCancellazionePermesso')))
  667. data['permessoSEP'] = getSEP(sede,amministratore)[1]
  668. ####################################
  669. listadirittidisponibili= Permesso.objects.filter(Q(classe='SED')|Q(classe='UTE')|Q(classe='DOC'))
  670. # diciamo che fatta cosi' mi pare una pecionata, ma funzionata. magari va ottimizzata un po'
  671. print(type(listadirittidisponibili))
  672. ldd = list()
  673. for i in listadirittidisponibili:
  674. ldd.append(i)
  675. print(type(ldd))
  676. print('*' * 20)
  677. data['listapermessiassegnabili'] = list()
  678. for i in ldd:
  679. if i not in data['permessoSEP']:
  680. data['listapermessiassegnabili'].append(i)
  681. ##########################################
  682. return render(request,'amministratore.edit.SEP.html',data)
  683. '''
  684. if 'ConfermaCancellazionePermessoXAmministratore' in request.POST:
  685. print("Premuto tasto ConfermaCancellazionePermessoXAmministratore")
  686. formcancellapermessoxamministratore = FormCancellaPermessiXAmministratore(request.POST)
  687. if formcancellapermessoxamministratore.is_valid():
  688. print('Form Valida CancellaPermessoXAmministratore')
  689. permessodarimuovere = formcancellapermessoxamministratore.cleaned_data.get('ConfermaCancellazionePermessoXAmministratore')
  690. print('Permesso da rimuovere',permessodarimuovere)
  691. amp = AMP.objects.get(pk=permessodarimuovere)
  692. amp.delete()
  693. if 'PermessoDaAggiungereButton' in request.POST:
  694. print("Premuto aggiunta permesso")
  695. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST)
  696. print(formpermessodaaggiungere)
  697. if formpermessodaaggiungere.is_valid():
  698. print("Form permessodaaggiungere valida")
  699. pda = Permesso.objects.get(pk=formpermessodaaggiungere.cleaned_data.get('permessodaaggiungere'))
  700. print('pda',pda.nome)
  701. amp = AMP()
  702. amp.amministratore = amministratore
  703. amp.permesso = pda
  704. amp.save()
  705. data['pane']='Permesso'
  706. if 'AziendaConfermaCancellazionePermesso' in request.POST:
  707. formcancellapermesso = FormCancellaPermessi(request.POST)
  708. if formcancellapermesso.is_valid():
  709. print('form valida formcancellapermesso')
  710. aziendadarimuovere = formcancellapermesso.cleaned_data.get('ConfermaCancellazionePermesso')
  711. print('azienda da rimuovere',aziendadarimuovere)
  712. #prima cosa togliamo i diritti alle sedi
  713. aztorm = None
  714. try:
  715. aztorm = Azienda.objects.get(pk=aziendadarimuovere)
  716. except Azienda.DoesNotExist:
  717. print('Azienda non trovata',aziendadarimuovere)
  718. print('azienda trovata',aztorm.nome)
  719. print("Iniziamo dalle sedi")
  720. sedi = aztorm.sede_set.all()
  721. for tmp in sedi:
  722. print('sede',tmp.nome)
  723. for p in tmp.sep_set.all():
  724. print('permesso',p.permesso.nome)
  725. p.delete()
  726. print("Ora tocca all'azienda")
  727. for p in aztorm.azp_set.all():
  728. print('permesso azienda',p.permesso.nome)
  729. p.delete()
  730. data['pane'] = "Azienda"
  731. listaaziendatutte = Azienda.objects.all()
  732. if amministratore.id:
  733. data['listaazienda'] = listaAZP(amministratore)[0]
  734. data['listaaziendadiff'] = list(set(listaaziendatutte)-set(data['listaazienda']))
  735. else:
  736. data['listaaziendadiff'] = list(set(listaaziendatutte))
  737. if 'AziendaDaAggiungereButton' in request.POST:
  738. formaziendamancante=FormAziendaMancante(request.POST)
  739. formaziendamancante.c(data['listaaziendadiff'])
  740. #print('fam',formaziendamancante)
  741. if formaziendamancante.is_valid():
  742. print('form valida formaziendamancante')
  743. aziendadaaggiungere = formaziendamancante.cleaned_data.get('aziendadaaggiungere')
  744. print('Azienda da aggiungere',aziendadaaggiungere)
  745. aztoadd = None
  746. try:
  747. aztoadd = Azienda.objects.get(pk=aziendadaaggiungere)
  748. except Azienda.DoesNotExist as dne:
  749. print("Azienda non trovata",aziendadaaggiungere)
  750. if aztoadd:
  751. print('Azienda in corso di aggiunta',aztoadd.nome)
  752. azp = AZP()
  753. azp.azienda = aztoadd
  754. azp.amministratore = amministratore
  755. azp.permesso = getPermesso("AZIENDA")
  756. print('permesso base',getPermesso("AZIENDA").nome)
  757. azp.save()
  758. print(azp.id)
  759. data['pane']='Azienda'
  760. if 'AziendaSelect' in request.POST:
  761. print('Richiesta Selezione Azienda')
  762. formaziendaselect = FormAziendaSelect(request.POST)
  763. if formaziendaselect.is_valid():
  764. print('FormAziendaSelect valido')
  765. aziendaselect = formaziendaselect.cleaned_data.get('AziendaSelect')
  766. request.session['aziendaselect'] = aziendaselect
  767. print('aziendaselect',aziendaselect)
  768. # una volta ottenuta l'azienda, selezioniamo le sedi:
  769. # le selezioni sono due:
  770. # 1 lista delle sedi gia' associate all'utente attraverso il permesso(SEP)
  771. # 2 lista delle sedi ancora da assegnare (tolte le sedi gia' assegnate)
  772. data['listasede'] = listaSEP(aziendaselect,amministratore)[0]
  773. data['listasedediff']= list(set(Azienda.objects.get(pk=aziendaselect).sede_set.all()) - set(listaSEP(aziendaselect,amministratore)[0]))
  774. print("lista sede",len(data['listasede']))
  775. data['pane']='Azienda'
  776. if 'SedeConfermaCancellazionePermesso' in request.POST:
  777. print('Richiesta cancellazione Permessi Sede')
  778. if 'SedeDaAggiungereButton' in request.POST:
  779. if 'aziendaselect' in request.session:
  780. aziendaselect = request.session.get('aziendaselect')
  781. print('Richiesta Sede da aggiungere')
  782. data['listasede'] = listaSEP(aziendaselect,amministratore)[0]
  783. data['listasedediff']= list(set(Azienda.objects.get(pk=aziendaselect).sede_set.all()) - set(listaSEP(aziendaselect,amministratore)[0]))
  784. print('listasedediff len',len(data['listasedediff']))
  785. formsedemancante = FormSedeMancante(request.POST,lista=data['listasedediff'])
  786. #formsedemancante.c(data['listasedediff'])
  787. if 'ListaSedeMancante' in request.POST:
  788. print('ListaSedeMancante',request.POST['ListaSedeMancanteSelect'])
  789. if formsedemancante.is_valid():
  790. listasedemancante = formsedemancante.cleaned_data.get('ListaSedeMancanteSelect')
  791. print(listasedemancante)
  792. for lsm in listasedemancante:
  793. setSEP(Sede.objects.get(pk=lsm),amministratore,Permesso.objects.get(nome="SEDE"))
  794. #else: print(formsedemancante)
  795. '''
  796. ### editing amministratore senza ulteriori funzioni ###
  797. def editAmministratore(request):
  798. if not 'AdminId' in request.session:
  799. return HttpResponseRedirect(reverse("login:start"))
  800. ### funzioni esterne ###
  801. d = DataDict()
  802. data = d.getData()
  803. data['NavBar']=True
  804. data['ShowSelectAzienda'] = False
  805. data['ShowSelectSede'] = False
  806. define = Define(request)
  807. data['admin'] = define.getAdmin()
  808. data['azienda'] = define.getAzienda()
  809. data['AziendaId'] = define.getAziendaId()
  810. data['sede'] = define.getSede()
  811. data['SedeId'] = define.getSedeId()
  812. print('cazzo cazzo')
  813. ### funzioni esterne fine ###
  814. if 'AdminId' in request.session:
  815. data['AdminId'] = request.session['AdminId']
  816. admin = Amministratore.objects.get(pk=data['AdminId'])
  817. data['admin'] = admin
  818. print('admin',admin.id,admin.nome)
  819. data['permesso'] = getAMP(admin)[0]
  820. amministratore = data['admin']
  821. print('amministratore',amministratore.id,amministratore.nome)
  822. if request.method == 'POST':
  823. print("qualcosa e' stato premuto")
  824. if 'indietro' in request.POST:
  825. return HttpResponseRedirect(reverse("azienda:welcome"))
  826. if 'AmministratoreDirittiAziendaButton' in request.POST:
  827. print("premuto: 'AmministratoreDirittiAziendaButton'")
  828. return HttpResponseRedirect(reverse("amministratore:editAZ"))
  829. if 'AmministratoreUpdateButton' in request.POST:
  830. formamministratore = FormAmministratore(request.POST)
  831. if formamministratore.is_valid():
  832. print('form valida formamministratore')
  833. amministratore.login=formamministratore.cleaned_data.get('login')
  834. amministratore.nome=formamministratore.cleaned_data.get('nome')
  835. amministratore.mail=formamministratore.cleaned_data.get('mail')
  836. amministratore.pin=formamministratore.cleaned_data.get('pin')
  837. amministratore.save()
  838. print('id amministratore salvato/nuovo',amministratore.id,":",amministratore.nome)
  839. tmp = dict()
  840. tmp['nome'] = amministratore.nome
  841. tmp['login'] = amministratore.login
  842. tmp['pin'] = amministratore.pin
  843. tmp['mail'] = amministratore.mail
  844. data['amministratore'] = FormAmministratore(tmp)
  845. return render(request,'amministratore.edit.html',data)