verejny kontaktnicek #71
					 1 changed files with 4 additions and 3 deletions
				
			
		|  | @ -121,9 +121,6 @@ def soustredeniKontaktnicekView(request, soustredeni, typ): | ||||||
|  	# nebyl jsi tam, nebo nejsi org |  	# nebyl jsi tam, nebo nejsi org | ||||||
| 	if (not request.user in [u.osoba.user for u in soustredeni.ucastnici.all()]) and not request.user.je_org: | 	if (not request.user in [u.osoba.user for u in soustredeni.ucastnici.all()]) and not request.user.je_org: | ||||||
| 
				
					
						ledoian
						commented  Uh, je to ekvivalentní s  Uh, je to ekvivalentní s `if request.user not in […] and not request.user.is_org:`? | |||||||
| 		raise PermissionDenied() | 		raise PermissionDenied() | ||||||
| 	# není k dispozici |  | ||||||
| 	if (not soustredeni.kontaktnicek_pdf and typ == "pdf") or (not soustredeni.kontaktnicek_vcf and typ == "vcf"): |  | ||||||
| 		raise Http404() |  | ||||||
| 	 | 	 | ||||||
| 	kontaktnicky = { | 	kontaktnicky = { | ||||||
| 
				
					
						ledoian
						commented  404 není správný návratový kód (kontaktníček zjevně existuje, ale nemám k němu přístup), má být 403 ( 404 není správný návratový kód (kontaktníček zjevně existuje, ale nemám k němu přístup), má být 403 (`PermissionDenied` se myslím jmenuje ta Djangová výjimka). | |||||||
| 		'pdf': (soustredeni.kontaktnicek_pdf, 'applcation/pdf', 'rb'), | 		'pdf': (soustredeni.kontaktnicek_pdf, 'applcation/pdf', 'rb'), | ||||||
| 
				
					
						ledoian
						commented  Poněkud se mi nelíbí místní duplikace kódu, když se tam mění dohromady tři věci (až přidáme další, tak někde něco zapomeneme přepsat a bude to bug…). Co třeba: Poněkud se mi nelíbí místní duplikace kódu, když se tam mění dohromady tři věci (až přidáme další, tak někde něco zapomeneme přepsat a bude to bug…). Co třeba:
```python3
# typ -> (field, mime_type, otevreni)
kontaktnicky = {
|   'pdf': (soustredeni.kontaktnicek_pdf, 'applcation/pdf', 'rb'),
|   'vcf': (soustredeni.kontaktnicek_vcf, 'text/vcard', 'r'), # vcf je texťák, nevím, jestli je potřeba ho otevítat binárně.
}
try:
	field, mime, otevreni = kontaktnicky[typ]
except KeyError as e:
	raise ValueError("Neznámý typ kontaktníčku") from e
if not field:
|   ...
with open(field.path, otevreni) as soubor:
|   return HttpResponse(soubor.read(), content_type=mime)
``` 
				
					
						ledoian
						commented  Uh, ten  Uh, ten `if not field: ...` byl náznak toho, že není potřeba výčet typů v `if (not soustredeni.kontaktnicek_pdf and typ == "pdf") or (not soustredeni.kontaktnicek_vcf and typ == "vcf"):`, sorry za neexplicitnost. | |||||||
|  | @ -135,6 +132,10 @@ def soustredeniKontaktnicekView(request, soustredeni, typ): | ||||||
| 	except KeyError as e: | 	except KeyError as e: | ||||||
| 
				
					
						ledoian
						commented  Možno rovnou: Možno rovnou:
```python3
with open(…) as whatever:
	return HttpResponse(…)
``` | |||||||
| 		raise ValueError("Neznámý typ kontaktníčku") from e | 		raise ValueError("Neznámý typ kontaktníčku") from e | ||||||
| 
 | 
 | ||||||
|  | 	# není k dispozici | ||||||
|  | 	if not field: | ||||||
|  | 		raise Http404() | ||||||
|  | 	 | ||||||
| 	with open(field.path, otevreni) as kontaktnicek: | 	with open(field.path, otevreni) as kontaktnicek: | ||||||
| 		response = HttpResponse(kontaktnicek.read(), content_type=mime) | 		response = HttpResponse(kontaktnicek.read(), content_type=mime) | ||||||
| 		response['Content-Disposition'] = 'attachment; filename="kontaktnicek.{}"'.format(typ) | 		response['Content-Disposition'] = 'attachment; filename="kontaktnicek.{}"'.format(typ) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	
Asi bych napsal popisnější hlášku, vynechal bych tu část z orgem, a naopak bych tam připsal, že nejsi přihlášený (to se stane asi častěji než že bych se dostal na špatný kontaktníček).
Také si nejsem jistý, jestli HttpResponse je to správné. (Jakože vrátí to něco, co moc nevypadá jako M&M stránky, ne?)