views.py 39 KB

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