views.py 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385
  1. from django.shortcuts import render
  2. from django.http import HttpResponseRedirect
  3. from django.urls import reverse
  4. from .models import *
  5. from config.views import *
  6. from att.views import *
  7. from .forms import *
  8. from sicurezza.views import getAMP,getAZP,getSEP
  9. def welcome(request):
  10. if not 'AdminId' in request.session:
  11. return HttpResponseRedirect(reverse("login:start"))
  12. AdminId = request.session['AdminId']
  13. print('AdminId',AdminId)
  14. data = dict()
  15. azienda = None
  16. if 'AziendaId' in request.session:
  17. AziendaId = request.session['AziendaId']
  18. print('AziendaId',AziendaId)
  19. azienda = Azienda.objects.get(pk=AziendaId)
  20. data['azienda'] = azienda
  21. sede = None
  22. if 'SedeId' in request.session:
  23. SedeId = request.session['SedeId']
  24. print('SedeId',SedeId)
  25. try:
  26. sede = Sede.objects.get(pk=SedeId)
  27. except Sede.DoesNotExist as dne:
  28. print("non esiste")
  29. data['sede'] = sede
  30. data['HeaderTitle'] = getConfig('HeaderTitle')
  31. data['Navbar']=True
  32. admin = Amministratore.objects.get(pk=AdminId)
  33. data['admin'] = admin
  34. data['permesso_amministratore'] = getAMP(admin)
  35. data['permesso_azienda'] = getAZP(azienda,admin)
  36. data['permesso_sede'] = getSEP(sede,admin)
  37. print('permesso_amministratore',data['permesso_amministratore'])
  38. print('permesso_azienda',data['permesso_azienda'])
  39. print('permesso_sede',data['permesso_sede'])
  40. print('admin',admin.id,admin.nome)
  41. assegnazioneazienda = AssegnazioneAzienda.objects.filter(amministratore=admin.id).order_by('azienda__nome')
  42. print('assegnazioneazienda',len(assegnazioneazienda))
  43. assegnazionesede=None
  44. if azienda:
  45. assegnazionesede = AssegnazioneSede.objects.filter(amministratore=admin,azienda=azienda).order_by('sede__nome')
  46. data['listaAttivitaxAmministrazione']=getLogxAmministrazione(admin)
  47. if request.method=="POST":
  48. print(request.POST)
  49. if 'indietro' in request.POST:
  50. print('premuto tast indietro,logout')
  51. return HttpResponseRedirect(reverse("login:start"))
  52. if "sceltaazienda" in request.POST:
  53. sceltaazienda = request.POST.get('sceltaazienda')
  54. try:
  55. sceltaazienda = int(sceltaazienda)
  56. except ValueError as ve:
  57. print("Non e' stata fatta la scelta corretta",ve)
  58. return HttpResponseRedirect(reverse('azienda:welcome'))
  59. print("sceltaazienda = ",request.POST.get('sceltaazienda'))
  60. # attività su nuova/edit azienda
  61. if sceltaazienda == -1: #richiesta una nuova azienda
  62. print('sceltaazienda -1:',sceltaazienda)
  63. #return HttpResponseRedirect(reverse('azienda:editAzienda'))
  64. elif sceltaazienda == 0:
  65. print('sceltaazienda 0:',sceltaazienda)
  66. request.session['AziendaIdEdit'] = 0
  67. print('AziendaId',request.session['AziendaIdEdit'])
  68. return HttpResponseRedirect(reverse('azienda:editAzienda'))
  69. else:
  70. try:
  71. azienda = Azienda.objects.get(pk=sceltaazienda)
  72. data['azienda'] = azienda
  73. request.session['AziendaId'] = azienda.id
  74. request.session['SedeId'] = -1
  75. if 'sede' in data:
  76. del data['sede']
  77. except Azienda.DoesNotExist as dne:
  78. print("errore, oggetto inesistente",dne)
  79. if "sceltasede" in request.POST:
  80. sceltasede = request.POST.get('sceltasede')
  81. try:
  82. sceltasede = int(sceltasede)
  83. request.session['SedeId'] = sceltasede
  84. except ValueError as ve:
  85. print("Non e' stata fatta la scelta corretta",ve)
  86. return HttpResponseRedirect(reverse('azienda:welcome'))
  87. print("sceltasede = ",request.POST.get('sceltasede'))
  88. if sceltasede == -1:
  89. print('sceltasede -1:',sceltasede)
  90. if 'sede' in data:
  91. del data['sede']
  92. elif sceltasede == 0: #richiesta una nuova azienda
  93. print('sceltasede 0:',sceltasede)
  94. request.session['SedeIdEdit'] = 0
  95. return HttpResponseRedirect(reverse('azienda:editSede'))
  96. else:
  97. try:
  98. sede = Sede.objects.get(pk=sceltasede)
  99. data['sede'] = sede
  100. request.session['SedeId'] = sede.id
  101. except Sede.DoesNotExist as dne:
  102. print("errore,oggetto inesistente",dne)
  103. if "utenti" in request.POST:
  104. print('premuto tasto utenti')
  105. return HttpResponseRedirect(reverse('utente:welcome'))
  106. if 'documenti' in request.POST:
  107. # stato premuto il tasto documenti
  108. print('premuto tasto documenti')
  109. return HttpResponseRedirect(reverse('documento:welcome'))
  110. if "attivita" in request.POST:
  111. print('premuto tasto attivita')
  112. print("azioenda:",azienda)
  113. data['listaAttivitaxAzienda']=getLogxAzienda(azienda)
  114. if 'comunicazioni' in request.POST:
  115. print('premuto tasto comunicazioni')
  116. return HttpResponseRedirect(reverse('comunicazione:welcome'))
  117. if 'parazienda' in request.POST:
  118. print('premuto tasto Par.Azienda')
  119. azid = request.POST.get('parazienda')
  120. print('azienda passata',request.POST.get('parazienda'))
  121. azienda = Azienda.objects.get(pk=azid)
  122. request.session['AziendaId'] = azienda.id
  123. request.session['AziendaIdEdit'] = azienda.id
  124. return HttpResponseRedirect(reverse('azienda:editAzienda'))
  125. if 'parsede' in request.POST:
  126. print('premuto tasto Par.Sede')
  127. seid = request.POST.get('parsede')
  128. print('sede passata',request.POST.get('parsede'))
  129. sede = Sede.objects.get(pk=seid)
  130. request.session['SedeId'] = sede.id
  131. request.session['SedeIdEdit'] = sede.id
  132. return HttpResponseRedirect(reverse('azienda:editSede'))
  133. if 'amministratore' in request.POST:
  134. print(' premuto tasto Amministratore')
  135. return HttpResponseRedirect(reverse('amministratore:welcome'))
  136. data['AziendaLista'] = assegnazioneazienda
  137. if 'azienda' in data:
  138. print('azienda selezionata:',data['azienda'].nome)
  139. data['SedeLista'] = data['azienda'].sede_set.all().order_by('nome')
  140. print('numero aziende',len(data['AziendaLista']))
  141. if 'SedeLista' in data:
  142. print('numero di sedi',len(data['SedeLista']))
  143. return render(request,'azienda.welcome.html',data)
  144. # creazione azienda
  145. def editAzienda(request):
  146. if not 'AdminId' in request.session:
  147. return HttpResponseRedirect(reverse("login:start"))
  148. AdminId = request.session['AdminId']
  149. print('AdminId',AdminId)
  150. data=dict()
  151. azienda = None
  152. if 'AziendaId' in request.session:
  153. AziendaId = request.session['AziendaId']
  154. print('AziendaId',AziendaId)
  155. azienda = Azienda.objects.get(pk=AziendaId)
  156. data['azienda'] = azienda
  157. sede = None
  158. if 'SedeId' in request.session:
  159. SedeId = request.session['SedeId']
  160. print('SedeId',SedeId)
  161. try:
  162. sede = Sede.objects.get(pk=SedeId)
  163. except Sede.DoesNotExist as dne:
  164. print("non esiste")
  165. data['sede'] = sede
  166. data['HeaderTitle'] = getConfig('HeaderTitle')
  167. user = data['admin'] = Amministratore.objects.get(pk=AdminId)
  168. azienda = None
  169. if 'AziendaIdEdit' in request.session:
  170. print('trovato riferimento AziendaIdEdit',request.session.get('AziendaIdEdit'))
  171. azid = request.session.get('AziendaIdEdit')
  172. try:
  173. azienda = Azienda.objects.get(pk=azid)
  174. print('azienda trovata',azienda.nome)
  175. except Azienda.DoesNotExist as dnf:
  176. print(dnf)
  177. data['permesso_amministratore'] = getAMP(AdminId)
  178. data['permesso_azienda'] = getAZP(azienda,AdminId)
  179. #data['permesso_sede'] = getSEP(sede,AdminId)
  180. print('permesso_amministratore',data['permesso_amministratore'])
  181. print('permesso_azienda',data['permesso_azienda'])
  182. #print('permesso_sede',data['permesso_sede'])
  183. if 'indietro' in request.POST:
  184. return HttpResponseRedirect(reverse('azienda:welcome'))
  185. if request.method == "POST":
  186. print("Richiesta creazione nuova azienda")
  187. nuovaazienda = formAzienda(request.POST)
  188. if nuovaazienda.is_valid():
  189. print("il form e' valido",request.POST)
  190. if not azienda:
  191. azienda = Azienda()
  192. azienda.nome = nuovaazienda.cleaned_data.get('nome')
  193. azienda.mail = nuovaazienda.cleaned_data.get('mail')
  194. azienda.partitaiva = nuovaazienda.cleaned_data.get('partitaiva')
  195. azienda.cambiopassword = nuovaazienda.cleaned_data.get('cambiopassword')
  196. azienda.forzanuovapassword = nuovaazienda.cleaned_data.get('forzanuovapassword')
  197. azienda.save()
  198. request.session['AziendaIdEdit'] = azienda.id
  199. print('azienda:',azienda.id)
  200. assegnazione = AssegnazioneAzienda()
  201. assegnazione.azienda=azienda
  202. assegnazione.amministratore=Amministratore.objects.get(pk=AdminId)
  203. assegnazione.save()
  204. del request.session['AziendaIdEdit']
  205. return HttpResponseRedirect(reverse('azienda:welcome'))
  206. else:
  207. print("form non valido")
  208. data['aziendaForm'] = formAzienda(request.POST)
  209. else: #non è un post
  210. print("Non è un post")
  211. formAziendaField = None
  212. if azienda:
  213. print('Abbiamo azienda',azienda.nome)
  214. tmp = dict()
  215. tmp['id'] = azienda.id
  216. tmp['nome'] = azienda.nome
  217. tmp['partitaiva'] = azienda.partitaiva
  218. tmp['mail'] = azienda.mail
  219. tmp['forzanuovapassword'] = azienda.forzanuovapassword
  220. tmp['cambiopassword'] = azienda.cambiopassword
  221. formAziendaField = formAzienda(tmp)
  222. else:
  223. tmp = dict()
  224. tmp['nome'] = ''
  225. tmp['partitaiva'] = ''
  226. tmp['mail'] = user.mail
  227. tmp['forzanuovapassword'] = False
  228. tmp['cambiopassword' ] = False
  229. formAziendaField = formAzienda(tmp)
  230. data['aziendaForm'] = formAziendaField
  231. return render(request,'azienda.editAzienda.html',data)
  232. def editSede(request):
  233. ''' edit Sedi azienda '''
  234. if not 'AdminId' in request.session:
  235. return HttpResponseRedirect(reverse("login:start"))
  236. AdminId = request.session['AdminId']
  237. print('AdminId',AdminId)
  238. data = dict()
  239. if 'AziendaId' in request.session:
  240. AziendaId = request.session['AziendaId']
  241. print('AziendaId',AziendaId)
  242. data['azienda'] = Azienda.objects.get(pk=AziendaId)
  243. if 'SedeId' in request.session:
  244. SedeId = request.session['SedeId']
  245. print('SedeId',SedeId)
  246. try:
  247. data['sede'] = Sede.objects.get(pk=SedeId)
  248. except Sede.DoesNotExist as dne:
  249. print("non esiste")
  250. data['HeaderTitle'] = getConfig('HeaderTitle')
  251. data['Navbar']=True
  252. data['HeaderTitle'] = getConfig('HeaderTitle')
  253. admin = data['admin'] = Amministratore.objects.get(pk=AdminId)
  254. flag = False
  255. if 'SedeIdEdit' in request.session:
  256. print('trovato riferimento SedeIdEdit',request.session.get('SedeIdEdit'))
  257. seid = request.session.get('SedeIdEdit')
  258. try:
  259. sede = Sede.objects.get(pk=seid)
  260. print('sede trovata',sede.nome)
  261. flag = True
  262. except Sede.DoesNotExist as dne:
  263. print('Sede indicata inesistente',dne)
  264. sede = Sede()
  265. sede.azienda = Azienda.objects.get(pk=AziendaId)
  266. print('sede.azienda',sede.azienda.nome)
  267. sede.cambiopassword = sede.azienda.cambiopassword
  268. sede.forzanuovapassword = sede.azienda.forzanuovapassword
  269. sede.otppassword = sede.azienda.otppassword
  270. data['permesso_amministratore'] = getAMP(AdminId)
  271. print('permesso_amministratore',data['permesso_amministratore'])
  272. if flag:
  273. data['permesso_sede'] = getSEP(sede,AdminId)
  274. print('permesso_sede',data['permesso_sede'])
  275. data['permesso_azienda'] = getAZP(AziendaId,AdminId)
  276. print('permesso_azienda',data['permesso_azienda'])
  277. if 'indietro' in request.POST:
  278. return HttpResponseRedirect(reverse('azienda:welcome'))
  279. if request.method == "POST":
  280. print("Richiesta creazione nuova azienda")
  281. nuovasede = formSede(request.POST)
  282. if nuovasede.is_valid():
  283. print("il form e' valido",request.POST)
  284. sede.nome = nuovasede.cleaned_data.get('nome')
  285. sede.mail = nuovasede.cleaned_data.get('mail')
  286. sede.cambiopassword = nuovasede.cleaned_data.get('cambiopassword')
  287. sede.forzanuovapassword = nuovasede.cleaned_data.get('forzanuovapassword')
  288. sede.otppassword = nuovasede.cleaned_data.get('otppassword')
  289. sede.info = nuovasede.cleaned_data.get('info')
  290. sede.identificativo = nuovasede.cleaned_data.get('identificativo')
  291. sede.save()
  292. print('salvataggio sede',nuovasede.cleaned_data)
  293. request.session['SedeIdEdit'] = sede.id
  294. print('sede:',sede.id)
  295. print('azienda',sede.azienda.nome)
  296. # verifica assegnazione
  297. az = AssegnazioneSede.objects.filter(sede=sede,amministratore=admin)
  298. print('assegnazione',az)
  299. if not az:
  300. az = AssegnazioneSede()
  301. az.sede=sede
  302. az.amministratore=admin
  303. az.save()
  304. print(sede.nome,admin.nome)
  305. print('az.admin',az.sede,az.amministratore.nome)
  306. return HttpResponseRedirect(reverse('azienda:welcome'))
  307. else:
  308. print("form non valido")
  309. data['sedeForm'] = formSede(request.POST)
  310. else: #non è un post
  311. print("Non è un post")
  312. tmp = dict()
  313. tmp['nome'] = sede.nome
  314. tmp['info'] = sede.info
  315. tmp['identificativo'] = sede.identificativo
  316. tmp['cambiopassword'] = sede.cambiopassword
  317. tmp['forzanuovapassword'] = sede.forzanuovapassword
  318. tmp['otppassword'] = sede.otppassword
  319. print('stato tmp',tmp)
  320. data['sedeForm'] = formSede(tmp)
  321. return render(request,'azienda.editSede.html',data)