views.py 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868
  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. 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. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST,permessi=data['listapermessiassegnabili'])
  248. if formpermessodaaggiungere.is_valid():
  249. print('formpermessodaaggiungere valido')
  250. permesso = formpermessodaaggiungere.cleaned_data.get('ListaPermessiDaAggiungere')
  251. print('*' * 10)
  252. setAMP(amministratore,int(permesso))
  253. print('*' * 10)
  254. else:
  255. print('non va: formpermessodaaggiungere',formpermessodaaggiungere)
  256. print('*' * 20)
  257. formpermessodarimuovere = FormPermessoDaRimuovere(request.POST)
  258. if formpermessodarimuovere.is_valid():
  259. print('formpermessodarimuovere valido')
  260. permesso = formpermessodarimuovere.cleaned_data.get('ConfermaCancellazionePermesso')
  261. print('ConfermaCancellazionePermesso',permesso)
  262. delAMP(amministratore,permesso)
  263. else:
  264. print('non va: formpermessodarimuovere',formpermessodarimuovere)
  265. else:
  266. print('che merda do operazione')
  267. print(request.POST)
  268. data['listapermessiassegnati'] = getAMP(data['amministratore'])[1]
  269. print('listapermessiassegnati',data['listapermessiassegnati'])
  270. data['listapermessiassegnabili'] = Permesso.objects.all()
  271. print('listapermessiassegnabili',data['listapermessiassegnabili'])
  272. return render(request,'amministratore.edit.AMP.html',data)
  273. def editAZ(request):
  274. ### edit lista aziende autorizzate
  275. if not 'AdminId' in request.session:
  276. return HttpResponseRedirect(reverse("login:start"))
  277. ### funzioni esterne ###
  278. d = DataDict()
  279. data = d.getData()
  280. data['NavBar']=True
  281. data['ShowSelectAzienda'] = False
  282. data['ShowSelectSede'] = False
  283. define = Define(request)
  284. data['admin'] = define.getAdmin()
  285. data['azienda'] = define.getAzienda()
  286. data['AziendaId'] = define.getAziendaId()
  287. data['sede'] = define.getSede()
  288. data['SedeId'] = define.getSedeId()
  289. ### funzioni esterne fine ###
  290. if 'AdminId' in request.session:
  291. data['AdminId'] = request.session['AdminId']
  292. admin = Amministratore.objects.get(pk=data['AdminId'])
  293. data['admin'] = admin
  294. print('admin',admin.id,admin.nome)
  295. data['permesso'] = getAMP(admin)[0]
  296. listaaziendatutte = Azienda.objects.all()
  297. if 'paramm' in request.session and request.session['paramm']:
  298. data['DONTSHOWDIRITTI']=True
  299. amministratore = None
  300. if 'AmministratoreEditId' in request.session:
  301. amministratoreEditId = request.session.get('AmministratoreEditId')
  302. try:
  303. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  304. except Amministratore.DoesNotExist as dne:
  305. return HttpResponseRedirect(reverse("amministratore:edit"))
  306. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  307. data['amministratore'] = amministratore
  308. if amministratore:
  309. data['listaazienda'] = listaAZP(amministratore)[0]
  310. data['listaaziendadiff'] = list(set(listaaziendatutte)-set(data['listaazienda']))
  311. else:
  312. data['listaaziendadiff'] = list(set(listaaziendatutte))
  313. #parliamo di diritti assegnati all'azienda.
  314. data['dirittiAZIENDA'] = Permesso.objects.filter(Q(classe='AZI')|Q(classe='SED'))
  315. print('dirittiAZIENDA',len(data['dirittiAZIENDA']))
  316. if request.method == 'POST':
  317. print("qualcosa e' stato premuto in editAZ")
  318. if 'AmministratoreReturnButton' in request.POST:
  319. print("Un tasto è stato premuto 'AmministratoreReturnButton'")
  320. return HttpResponseRedirect(reverse("amministratore:welcome"))
  321. if 'AmministratoreButton' in request.POST:
  322. print("Un tasto è stato premuto 'AmministratoreButton'")
  323. return HttpResponseRedirect(reverse("amministratore:edit"))
  324. if 'AziendaDaAggiungereButton' in request.POST:
  325. print('un tasto è stato premuto AziendaDaAggiungereButton')
  326. formaziendadaaggiungere = FormAziendaDaAggiungere(request.POST,azienda=listaaziendatutte)
  327. if formaziendadaaggiungere.is_valid():
  328. print('AziendaDaAggiungere, form valida')
  329. azienda = formaziendadaaggiungere.cleaned_data.get('ListaAziendaDaAggiungere')
  330. print(azienda)
  331. setAZP(azienda,amministratore,'AZIENDA')
  332. else:
  333. print('AziendaDaAggiungere, form non valido')
  334. if 'SedeButton' in request.POST:
  335. print("Un tasto è stato premuto 'SedeButton'")
  336. azienda = request.POST.get('SedeButton')
  337. request.session['EditAziendaId'] = azienda
  338. return HttpResponseRedirect(reverse("amministratore:editSEP"))
  339. if 'PermessoButton' in request.POST:
  340. print("Un tasto è stato premuto 'PermessoButton")
  341. azienda = request.POST.get('PermessoButton')
  342. request.session['EditAziendaPermessoId'] = azienda
  343. return HttpResponseRedirect(reverse("amministratore:editAZP"))
  344. if 'ConfermaCancellazioneAzienda' in request.POST:
  345. print("Un tasto è stato premuto 'ConfermaCancellazioneAzienda'")
  346. azi = int(request.POST.get('ConfermaCancellazioneAzienda'))
  347. delAZP(azi,amministratore)
  348. if amministratore:
  349. data['listaazienda'] = listaAZP(amministratore)[0]
  350. data['listaaziendadiff'] = list(set(listaaziendatutte)-set(data['listaazienda']))
  351. else:
  352. data['listaaziendadiff'] = list(set(listaaziendatutte))
  353. return render(request,'amministratore.edit.AZ.html',data)
  354. def editAZP(request):
  355. ### edit diritti associati all'azienda.
  356. ### in questa sezione procediamo con l'assegnare o rimuovere i diritti di questo amministratore
  357. ### per le aziende in elenco.
  358. if not 'AdminId' in request.session:
  359. return HttpResponseRedirect(reverse("login:start"))
  360. ### funzioni esterne ###
  361. d = DataDict()
  362. data = d.getData()
  363. data['NavBar']=True
  364. data['ShowSelectAzienda'] = False
  365. data['ShowSelectSede'] = False
  366. define = Define(request)
  367. data['admin'] = define.getAdmin()
  368. data['azienda'] = define.getAzienda()
  369. data['AziendaId'] = define.getAziendaId()
  370. data['sede'] = define.getSede()
  371. data['SedeId'] = define.getSedeId()
  372. ### funzioni esterne fine ###
  373. if 'AdminId' in request.session:
  374. data['AdminId'] = request.session['AdminId']
  375. admin = Amministratore.objects.get(pk=data['AdminId'])
  376. data['admin'] = admin
  377. print('admin',admin.id,admin.nome)
  378. data['permessoAMP'] = getAMP(admin)[1]
  379. amministratore = None
  380. if 'AmministratoreEditId' in request.session:
  381. amministratoreEditId = request.session.get('AmministratoreEditId')
  382. try:
  383. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  384. except Amministratore.DoesNotExist as dne:
  385. return HttpResponseRedirect(reverse("amministratore:edit"))
  386. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  387. data['amministratore'] = amministratore
  388. if 'EditAziendaPermessoId' in request.session:
  389. azienda = Azienda.objects.get(pk=request.session.get('EditAziendaPermessoId'))
  390. print('azienda',azienda.nome)
  391. data['aziendaOnWork'] = azienda
  392. data['permessoAZP'] = getAZP(azienda,amministratore)[1]
  393. if 'paramm' in request.session and request.session['paramm']:
  394. data['DONTSHOWDIRITTI']=True
  395. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  396. data['amministratore'] = amministratore
  397. ####################################
  398. listadirittidisponibili= Permesso.objects.filter(Q(classe='AZI')|Q(classe='SED')|Q(classe='UTE')|Q(classe='DOC'))
  399. # diciamo che fatta cosi' mi pare una pecionata, ma funzionata. magari va ottimizzata un po'
  400. print(type(listadirittidisponibili))
  401. ldd = list()
  402. for i in listadirittidisponibili:
  403. ldd.append(i)
  404. print(type(ldd))
  405. print('*' * 20)
  406. data['listapermessiassegnabili'] = list()
  407. for i in ldd:
  408. if i not in data['permessoAZP']:
  409. data['listapermessiassegnabili'].append(i)
  410. ##########################################
  411. if request.method == 'POST':
  412. print("qualcosa e' stato premuto")
  413. if 'AmministratoreReturnButton' in request.POST:
  414. print("Un tasto è stato premuto 'AmministratoreReturnButton'")
  415. return HttpResponseRedirect(reverse("amministratore:welcome"))
  416. if 'AmministratoreButton' in request.POST:
  417. print("Un tasto è stato premuto 'AmministratoreButton'")
  418. return HttpResponseRedirect(reverse("amministratore:edit"))
  419. if 'PermessoDaAggiungereButton' in request.POST:
  420. print("Un tasto è stato premuto 'PermessoDaAggiungereButton'")
  421. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST,permessi=data['listapermessiassegnabili'])
  422. if formpermessodaaggiungere.is_valid():
  423. print('listapermessidaaggiungere',formpermessodaaggiungere.cleaned_data.get('ListaPermessiDaAggiungere'))
  424. setAZP(azienda,amministratore,int(formpermessodaaggiungere.cleaned_data.get('ListaPermessiDaAggiungere')))
  425. else:
  426. print('errore formpermessodaaggiungere',formpermessodaaggiungere)
  427. if 'ConfermaCancellazionePermesso' in request.POST:
  428. print("Un tasto è stato premuto 'ConfermaCancellazionePermesso'")
  429. delAZP(azienda,amministratore,int(request.POST.get('ConfermaCancellazionePermesso')))
  430. data['permessoAZP'] = getAZP(azienda,amministratore)[1]
  431. ####################################
  432. listadirittidisponibili= Permesso.objects.filter(Q(classe='AZI')|Q(classe='SED')|Q(classe='UTE')|Q(classe='DOC'))
  433. # diciamo che fatta cosi' mi pare una pecionata, ma funzionata. magari va ottimizzata un po'
  434. print(type(listadirittidisponibili))
  435. ldd = list()
  436. for i in listadirittidisponibili:
  437. ldd.append(i)
  438. print(type(ldd))
  439. print('*' * 20)
  440. data['listapermessiassegnabili'] = list()
  441. for i in ldd:
  442. if i not in data['permessoAZP']:
  443. data['listapermessiassegnabili'].append(i)
  444. ##########################################
  445. return render(request,'amministratore.edit.AZP.html',data)
  446. def editSEP(request):
  447. ### edit diritti associati alla sede
  448. ### in questa sezione procediamo con l'assegnare o rimuovere i diritti di questo amministratore
  449. ### per le sedi in elenco.
  450. if not 'AdminId' in request.session:
  451. return HttpResponseRedirect(reverse("login:start"))
  452. ### funzioni esterne ###
  453. d = DataDict()
  454. data = d.getData()
  455. data['NavBar']=True
  456. data['ShowSelectAzienda'] = False
  457. data['ShowSelectSede'] = False
  458. define = Define(request)
  459. data['admin'] = define.getAdmin()
  460. data['azienda'] = define.getAzienda()
  461. data['AziendaId'] = define.getAziendaId()
  462. data['sede'] = define.getSede()
  463. data['SedeId'] = define.getSedeId()
  464. ### funzioni esterne fine ###
  465. if not 'EditAziendaId' in request.session:
  466. HttpResponseRedirect(reverse("amministratore:editAZ"))
  467. if 'AdminId' in request.session:
  468. data['AdminId'] = request.session['AdminId']
  469. admin = Amministratore.objects.get(pk=data['AdminId'])
  470. data['admin'] = admin
  471. print('admin',admin.id,admin.nome)
  472. data['permesso'] = getAMP(admin)[0]
  473. amministratore = None
  474. if 'AmministratoreEditId' in request.session:
  475. amministratoreEditId = request.session.get('AmministratoreEditId')
  476. try:
  477. amministratore = Amministratore.objects.get(pk=amministratoreEditId)
  478. except Amministratore.DoesNotExist as dne:
  479. return HttpResponseRedirect(reverse("amministratore:editSEP"))
  480. print('amministratore',amministratore.id,amministratore.login,amministratore.nome)
  481. data['amministratore'] = amministratore
  482. azienda = Azienda.objects.get(pk=request.session.get('EditAziendaId'))
  483. print('azienda',azienda.nome)
  484. data['aziendaOnWork'] = azienda
  485. data['listasede'] = listaSEP(azienda,amministratore.id,"SEDE")[0]
  486. data['listasede'].sort(key=lambda x: x.nome,reverse=False)
  487. print("data['listasede']",len(data['listasede']),type(data['listasede']))
  488. listasedetutte = azienda.sede_set.all().order_by('nome')
  489. print('listasedetutte',len(listasedetutte))
  490. data['listasedediff'] = list(set(listasedetutte)-set(data['listasede']))
  491. data['listasedediff'].sort(key=lambda x: x.nome,reverse=False)
  492. #data['listasedediff'] = listasedetutte
  493. print("data['listasedediff']",len(data['listasedediff']))
  494. # parliamo di diritti relativi alle sedi
  495. data['dirittiSEDE'] = Permesso.objects.filter(classe='SED')
  496. print('dirittiSEDE',len(data['dirittiSEDE']))
  497. print('minchia')
  498. if request.method == 'POST':
  499. print("qualcosa é stato premuto")
  500. if 'AmministratoreReturnButton' in request.POST:
  501. print("Un tasto è stato premuto 'AmministratoreReturnButton'")
  502. return HttpResponseRedirect(reverse("amministratore:welcome"))
  503. if 'AmministratoreButton' in request.POST:
  504. print("Un tasto è stato premuto 'AmministratoreButton'")
  505. return HttpResponseRedirect(reverse("amministratore:edit"))
  506. if 'AmministratoreEditAZPButton' in request.POST:
  507. print("Un tasto è stato premuto 'AmministratoreEditAZPButton'")
  508. return HttpResponseRedirect(reverse("amministratore:editAZ"))
  509. if 'SedeConfermaCancellazionePermessoButton' in request.POST:
  510. print("un tasto è stato premuto 'SedeConfermaCancellazionePermessoButton'")
  511. sede = request.POST['SedeConfermaCancellazionePermessoButton']
  512. print('Sede da rimuovere',sede)
  513. p = Permesso.objects.get(nome="SEDE")
  514. lista = SEP.objects.filter(sede=sede,amministratore=amministratore,permesso=p)
  515. print('lista lista',lista)
  516. for p in lista:
  517. p.delete()
  518. p = Permesso.objects.get(nome="DOCUMENTO")
  519. lista = SEP.objects.filter(sede=sede,amministratore=amministratore,permesso=p)
  520. print('lista lista',lista)
  521. for p in lista:
  522. p.delete()
  523. p = Permesso.objects.get(nome="UTENTE")
  524. lista = SEP.objects.filter(sede=sede,amministratore=amministratore,permesso=p)
  525. print('lista lista',lista)
  526. for p in lista:
  527. p.delete()
  528. if 'SedeDaAggiungereButton' in request.POST:
  529. print('un tasto è stato premuto SedeDaAggiungereButton')
  530. formsededaaggiungere = FormSedeDaAggiungere(request.POST,sede=data['listasedediff'])
  531. if formsededaaggiungere.is_valid():
  532. print('SedeDaAggiungere, form valida')
  533. sede = formsededaaggiungere.cleaned_data.get('ListaSedeDaAggiungere')
  534. print('id sede da aggiungere',sede)
  535. setSEP(sede,amministratore,'SEDE')
  536. setSEP(sede,amministratore,'UTENTE')
  537. setSEP(sede,amministratore,'DOCUMENTO')
  538. else:
  539. print('SedeDaAggiungere, form non valido')
  540. if 'SedePermessoUpdateButton' in request.POST:
  541. print("Un tasto è stato premuto 'SedePermessoUpdate'")
  542. print(request.POST)
  543. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST)
  544. formpermessodaaggiungere.c(Permesso.objects.filter(classe="SED"))
  545. if formpermessodaaggiungere.is_valid():
  546. print('formpermessodaaggiungere è valido')
  547. print("cazzo cazzo")
  548. else:
  549. print('errore',formpermessodaaggiungere)
  550. #formpermessoupdate = form.PermessoUpdate(request.POST)
  551. data['listasede'] = listaSEP(azienda,amministratore.id,"SEDE")[0]
  552. data['listasede'].sort(key=lambda x: x.nome,reverse=False)
  553. print("data['listasede']",len(data['listasede']),type(data['listasede']))
  554. listasedetutte = azienda.sede_set.all().order_by('nome')
  555. print('listasedetutte',len(listasedetutte))
  556. data['listasedediff'] = list(set(listasedetutte)-set(data['listasede']))
  557. data['listasedediff'].sort(key=lambda x: x.nome,reverse=False)
  558. #data['listasedediff'] = listasedetutte
  559. print("data['listasedediff']",len(data['listasedediff']))
  560. # parliamo di diritti relativi alle sedi
  561. data['dirittiSEDE'] = Permesso.objects.filter(classe='SED')
  562. print('dirittiSEDE',len(data['dirittiSEDE']))
  563. return render(request,'amministratore.edit.SEP.html',data)
  564. '''
  565. if 'ConfermaCancellazionePermessoXAmministratore' in request.POST:
  566. print("Premuto tasto ConfermaCancellazionePermessoXAmministratore")
  567. formcancellapermessoxamministratore = FormCancellaPermessiXAmministratore(request.POST)
  568. if formcancellapermessoxamministratore.is_valid():
  569. print('Form Valida CancellaPermessoXAmministratore')
  570. permessodarimuovere = formcancellapermessoxamministratore.cleaned_data.get('ConfermaCancellazionePermessoXAmministratore')
  571. print('Permesso da rimuovere',permessodarimuovere)
  572. amp = AMP.objects.get(pk=permessodarimuovere)
  573. amp.delete()
  574. if 'PermessoDaAggiungereButton' in request.POST:
  575. print("Premuto aggiunta permesso")
  576. formpermessodaaggiungere = FormPermessoDaAggiungere(request.POST)
  577. print(formpermessodaaggiungere)
  578. if formpermessodaaggiungere.is_valid():
  579. print("Form permessodaaggiungere valida")
  580. pda = Permesso.objects.get(pk=formpermessodaaggiungere.cleaned_data.get('permessodaaggiungere'))
  581. print('pda',pda.nome)
  582. amp = AMP()
  583. amp.amministratore = amministratore
  584. amp.permesso = pda
  585. amp.save()
  586. data['pane']='Permesso'
  587. if 'AziendaConfermaCancellazionePermesso' in request.POST:
  588. formcancellapermesso = FormCancellaPermessi(request.POST)
  589. if formcancellapermesso.is_valid():
  590. print('form valida formcancellapermesso')
  591. aziendadarimuovere = formcancellapermesso.cleaned_data.get('ConfermaCancellazionePermesso')
  592. print('azienda da rimuovere',aziendadarimuovere)
  593. #prima cosa togliamo i diritti alle sedi
  594. aztorm = None
  595. try:
  596. aztorm = Azienda.objects.get(pk=aziendadarimuovere)
  597. except Azienda.DoesNotExist:
  598. print('Azienda non trovata',aziendadarimuovere)
  599. print('azienda trovata',aztorm.nome)
  600. print("Iniziamo dalle sedi")
  601. sedi = aztorm.sede_set.all()
  602. for tmp in sedi:
  603. print('sede',tmp.nome)
  604. for p in tmp.sep_set.all():
  605. print('permesso',p.permesso.nome)
  606. p.delete()
  607. print("Ora tocca all'azienda")
  608. for p in aztorm.azp_set.all():
  609. print('permesso azienda',p.permesso.nome)
  610. p.delete()
  611. data['pane'] = "Azienda"
  612. listaaziendatutte = Azienda.objects.all()
  613. if amministratore.id:
  614. data['listaazienda'] = listaAZP(amministratore)[0]
  615. data['listaaziendadiff'] = list(set(listaaziendatutte)-set(data['listaazienda']))
  616. else:
  617. data['listaaziendadiff'] = list(set(listaaziendatutte))
  618. if 'AziendaDaAggiungereButton' in request.POST:
  619. formaziendamancante=FormAziendaMancante(request.POST)
  620. formaziendamancante.c(data['listaaziendadiff'])
  621. #print('fam',formaziendamancante)
  622. if formaziendamancante.is_valid():
  623. print('form valida formaziendamancante')
  624. aziendadaaggiungere = formaziendamancante.cleaned_data.get('aziendadaaggiungere')
  625. print('Azienda da aggiungere',aziendadaaggiungere)
  626. aztoadd = None
  627. try:
  628. aztoadd = Azienda.objects.get(pk=aziendadaaggiungere)
  629. except Azienda.DoesNotExist as dne:
  630. print("Azienda non trovata",aziendadaaggiungere)
  631. if aztoadd:
  632. print('Azienda in corso di aggiunta',aztoadd.nome)
  633. azp = AZP()
  634. azp.azienda = aztoadd
  635. azp.amministratore = amministratore
  636. azp.permesso = getPermesso("AZIENDA")
  637. print('permesso base',getPermesso("AZIENDA").nome)
  638. azp.save()
  639. print(azp.id)
  640. data['pane']='Azienda'
  641. if 'AziendaSelect' in request.POST:
  642. print('Richiesta Selezione Azienda')
  643. formaziendaselect = FormAziendaSelect(request.POST)
  644. if formaziendaselect.is_valid():
  645. print('FormAziendaSelect valido')
  646. aziendaselect = formaziendaselect.cleaned_data.get('AziendaSelect')
  647. request.session['aziendaselect'] = aziendaselect
  648. print('aziendaselect',aziendaselect)
  649. # una volta ottenuta l'azienda, selezioniamo le sedi:
  650. # le selezioni sono due:
  651. # 1 lista delle sedi gia' associate all'utente attraverso il permesso(SEP)
  652. # 2 lista delle sedi ancora da assegnare (tolte le sedi gia' assegnate)
  653. data['listasede'] = listaSEP(aziendaselect,amministratore)[0]
  654. data['listasedediff']= list(set(Azienda.objects.get(pk=aziendaselect).sede_set.all()) - set(listaSEP(aziendaselect,amministratore)[0]))
  655. print("lista sede",len(data['listasede']))
  656. data['pane']='Azienda'
  657. if 'SedeConfermaCancellazionePermesso' in request.POST:
  658. print('Richiesta cancellazione Permessi Sede')
  659. if 'SedeDaAggiungereButton' in request.POST:
  660. if 'aziendaselect' in request.session:
  661. aziendaselect = request.session.get('aziendaselect')
  662. print('Richiesta Sede da aggiungere')
  663. data['listasede'] = listaSEP(aziendaselect,amministratore)[0]
  664. data['listasedediff']= list(set(Azienda.objects.get(pk=aziendaselect).sede_set.all()) - set(listaSEP(aziendaselect,amministratore)[0]))
  665. print('listasedediff len',len(data['listasedediff']))
  666. formsedemancante = FormSedeMancante(request.POST,lista=data['listasedediff'])
  667. #formsedemancante.c(data['listasedediff'])
  668. if 'ListaSedeMancante' in request.POST:
  669. print('ListaSedeMancante',request.POST['ListaSedeMancanteSelect'])
  670. if formsedemancante.is_valid():
  671. listasedemancante = formsedemancante.cleaned_data.get('ListaSedeMancanteSelect')
  672. print(listasedemancante)
  673. for lsm in listasedemancante:
  674. setSEP(Sede.objects.get(pk=lsm),amministratore,Permesso.objects.get(nome="SEDE"))
  675. #else: print(formsedemancante)
  676. '''
  677. ### editing amministratore senza ulteriori funzioni ###
  678. def editAmministratore(request):
  679. if not 'AdminId' in request.session:
  680. return HttpResponseRedirect(reverse("login:start"))
  681. ### funzioni esterne ###
  682. d = DataDict()
  683. data = d.getData()
  684. data['NavBar']=True
  685. data['ShowSelectAzienda'] = False
  686. data['ShowSelectSede'] = False
  687. define = Define(request)
  688. data['admin'] = define.getAdmin()
  689. data['azienda'] = define.getAzienda()
  690. data['AziendaId'] = define.getAziendaId()
  691. data['sede'] = define.getSede()
  692. data['SedeId'] = define.getSedeId()
  693. print('cazzo cazzo')
  694. ### funzioni esterne fine ###
  695. if 'AdminId' in request.session:
  696. data['AdminId'] = request.session['AdminId']
  697. admin = Amministratore.objects.get(pk=data['AdminId'])
  698. data['admin'] = admin
  699. print('admin',admin.id,admin.nome)
  700. data['permesso'] = getAMP(admin)[0]
  701. amministratore = data['admin']
  702. print('amministratore',amministratore.id,amministratore.nome)
  703. if request.method == 'POST':
  704. print("qualcosa e' stato premuto")
  705. if 'indietro' in request.POST:
  706. return HttpResponseRedirect(reverse("azienda:welcome"))
  707. if 'AmministratoreDirittiAziendaButton' in request.POST:
  708. print("premuto: 'AmministratoreDirittiAziendaButton'")
  709. return HttpResponseRedirect(reverse("amministratore:editAZ"))
  710. if 'AmministratoreUpdateButton' in request.POST:
  711. formamministratore = FormAmministratore(request.POST)
  712. if formamministratore.is_valid():
  713. print('form valida formamministratore')
  714. amministratore.login=formamministratore.cleaned_data.get('login')
  715. amministratore.nome=formamministratore.cleaned_data.get('nome')
  716. amministratore.mail=formamministratore.cleaned_data.get('mail')
  717. amministratore.pin=formamministratore.cleaned_data.get('pin')
  718. amministratore.save()
  719. print('id amministratore salvato/nuovo',amministratore.id,":",amministratore.nome)
  720. tmp = dict()
  721. tmp['nome'] = amministratore.nome
  722. tmp['login'] = amministratore.login
  723. tmp['pin'] = amministratore.pin
  724. tmp['mail'] = amministratore.mail
  725. data['amministratore'] = FormAmministratore(tmp)
  726. return render(request,'amministratore.edit.html',data)