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?)