Petites découvertes ou redécouvertes des derniers jours.

 Django  Comments Off on Petites découvertes ou redécouvertes des derniers jours.
Feb 082025
 

Le CSRF , mais pourquoi faire ?

Imaginons, juste comme ça hypothétiquement, que vous vouliez désactiver de manière globale la protection CSRF sur la totalité des urls d’un site django.

Vous pensez qu’il suffit de désactiver le middleware qui va bien (soit django.middleware.csrf.CsrfViewMiddleware ) pour que op c’est bon, la vérification CSRF n’est plus mise en place ?

Vous serez alors décontenancé de voir que non, cela ne suffit pas. Il faut aussi ajouter le décorateur csrf_exempt ( qui se trouve dans django.views.decorators.csrf ) sur chacune de vos urls. Un peu compliqué en vrai, surtout si vous avez beaucoup d’urls. _

Comment faire ?

Tout simplement coder un middleware qui va l’enlever pour vous. Vous n’aurez ensuite qu’à le déclarer dans les middleware actifs.


class NOCSRFMiddleware(object):
def __init__(self, get_response):
        self.get_response = get_response

    def __call__(self, request):
        setattr(request, '_dont_enforce_csrf_checks', True)
        response = self.get_response(request)
        return response

Et voila ! Il suffit ensuite de le déclarer dans MIDDLEWARE et le tour est joué ( par exemple avec un  BadIdeaApp.BadMiddleware.NOCSRFMiddleware

Groupons, Groupons, Groupons !!!

J’avais totalement oublié l’existence du templatetags regroup qui permet de regrouper des objets identique par un attribut commun. Comme regrouper une liste de dictionnaires par les valeurs de l’un des attributs. La documentation complète est disponible ici : https://docs.djangoproject.com/en/4.2/ref/templates/builtins/#regroup

Et redécouvrir ce templatetags m’a été bien utile. Surtout en le couplant avec un autre templatetags que j’avais également oublié, dicsort ( https://docs.djangoproject.com/fr/4.2/ref/templates/builtins/#std-templatefilter-dictsort) qui va trier une liste de dictionnaire par une des clés des dictionnaires.

 Posted by at 00:41
Jan 052025
 

Je me suis retrouvé il y a quelques temps avec une problématique, remplacer une chaine par une autre dans un attribut CharField d’un model django.

La première possibilité était de faire tout simplement une belle boucle sur la totalité de mes instances de module, faire le remplacement en python et sauvegarder la nouvelle valeur.


Sauf que j’avais quasiment un million d’objet et que je n’avais pas envie que cela prenne des plombes. Et puis c’était un peu moche.

Du coup j’ai un peu fouillé et miracle, j’ai trouvé une solution que voici.

On commence par définir la fonction de remplacement, tout en django et en SQL.


from django.db.models import F, Func, Value
def replace_func(field_name, old_str, replace_str):
    return Func(
        F(field_name),
        Value(old_str), Value(replace_str),
        function='replace'
    )

Ensuite, il n’y a quasiment plus rien à faire. On va simplement appeler update sur tout les objets et utiliser replace_func.

Par exemple :


MonModele.objects.filter(CONDITIONS).update(
    champ_a_modifier=replace_func("champ_a_modifier",
                                  "str_que_lon_veut_remplacer",
                                  "nouvelle_chaine_de_caractere")

Et voila, c’est fini.

 Posted by at 00:55

Configurer les représentations textuelles qui seront utilisées dans les ChoiceField des forms Django.

 Django  Comments Off on Configurer les représentations textuelles qui seront utilisées dans les ChoiceField des forms Django.
Jul 282018
 

Longtemps que je n’avais pas posté de billets dans cette partie du blog. (Vous allez me dire longtemps que je n’ai pas posté de billet tout court, et vous auriez raison, mais ma bonne résolution de fin de vacances d’été est de changer cela).

Mais donc, pour reprendre doucement dans la partie technique, je vais commencer par partager un truc que tout le monde connaît sûrement déjà. Sauf que perso, j’oublie à chaque fois que cette fonctionnalité de django existe et donc je galère pour la retrouver. Du coup je me dis qu’en l’écrivant je finirais par la mémoriser (et donc en fait j’écris plus pour moi qu’autre chose, je suis un vilain !:) ).

Donc imaginons que vous avez un modèle. Truc assez classique. Ce modèle vous lui avez défini une représentation textuelle de base avec str . Sauf que vous avez plusieurs forms, donc certains ont des ChoiceFields utilisant ce modèle (Exemple un modèle User et vous avez un modèle Post où vous devez choisir le rédacteur du billet). Et manque de chance, vous avez besoin d’une représentation textuelle différentes de celle de base pour un de vos forms. Où même pire, vous avez besoin de plusieurs représentations textuelles différentes, pour plein de forms différents.

Vous êtes alors bien marri.

Mais en fait non, parce que Django vous fourni une façon à la fois simple et élégante de faire. A chaque fois que vous aurez besoin d’une représentation textuelle qui ne soit pas celle par défaut, il vous suffira de définir une classe dérivant de ModelChoiceField et qui implémentera la méthode label_from_instance. Cette méthode prend comme unique paramètre l’objet qui doit voir sa représentation textuelle définit et renvoie une chaîne de caractère.

Petit exemple tiré de la doc django :

from django.forms import ModelChoiceField

class MyModelChoiceField(ModelChoiceField):
    def label_from_instance(self, obj):
        return "My Object #%i" % obj.id

Voilà. Aussi simple que cela. Vous n’avez plus qu’à utiliser votre classe fille de ModelChoiceField dans votre formulaire et le tour et joué.

Bonus, ça marche aussi pour les MultipleChoiceField, il faudra simplement définir une classe fille de ModelMultipleChoiceField

et le lien vers la doc qui parle de tout cela : (https://docs.djangoproject.com/fr/2.0/ref/forms/fields/)

 Posted by at 22:22

Pyconfr au pays des galettes saucisses !

 Python  Comments Off on Pyconfr au pays des galettes saucisses !
Oct 202016
 

Ce week-end (enfin en vrai depuis jeudi si on compte les sprints) c’était donc le week-end de la Pyconfr. Et c’était à Rennes. Je ne dis pas ça comme un reproche, même si je nierais l’avoir écrit, j’aime plutôt bien Rennes. Bon d’accord il pleut tout le temps et il semblerait qu’un certains nombre de personne de bonne compagnie perdent tout sens commun quand il est question de choisir un lieu d’habitation et choisissent Rennes .. Mais hormis ces deux défauts (et aussi le fait qu’il y a rien d’ouvert le dimanche, non de non), c’est plutôt sympa comme ville.

Donc la pyconFr.

Etant à Lille les trois jours précédents, j’ai loupé la soirée d’ouverture qui avait l’air d’être plus que cool (ben oui, même si il y a des TGV direct Lille → Rennes, ils mettent quand même 4h à faire le trajet, donc en partant à 18h, c’était un peu mort pour la soirée).

Le samedi.

Fichtre le monde, fut la première chose qui m’a traversé l’esprit quand je suis arrivé samedi matin. Et effectivement, le fait qu’il y avait beaucoup, beaucoup beaucoup de monde s’est ressenti toute la journée. Dans les salles de conf pleines avec des gens debout, par terre, en mode sardine la belle-iloise, dans les queues face aux trois food truck qui s’occupaient de nous nourrir à la pause midi et dans la vitesse à laquelle les thermos de café se vidaient à peine posées sur la table.

Les confs en elles-mêmes portaient beaucoup sur deux sujets :  machine learning et d’asyncio. Ça tombait bien, c’est deux sujets qui m’interressent beaucoup en ce moment.

Mais à priori c’est deux sujets qui intéressent beaucoup de monde. Et les salles n’étaient malheureusement pas prévu pour le nombre de pythonistes présent. Ce qui fait que pour certaines conférences, il y a parfois eu des gens qui n’ont pas pu rentrer parce que les salles n’étaient pas assez grande. Heureusement qu’il y aura les vidéos (parce que bien entendu, je fais parti de ceux qui ne purent, au moins une fois, pas voir une conf).

Le dimanche.

M’étant levé un peu tard, (amener toute sa famille pour pyconfr n’aide pas à être à l’heure le dimanche matin, ranger une chambre d’hôtel en vérifiant bien qu’on n’y oublie rien, cela prend du temps .. [je ne veux même pas imaginer ce que donnerais l’oubli d’un doudou à l’hôtel…] ) je n’ai pas pu assister à toutes les confs du matin (et en plus honte sur moi, j’ai loupé l’AG de l’afpy … ce qui n’est pas bien du tout). Et comme j’avais un TGV à 16h, idem, je n’ai pas vraiment pu profiter de l’après-midi de conf. Mais  le « bref » moment que j’ai pu rester le dimanche m’a tout de même permis de discuter plus longuement avec les personnes avec qui je n’avais pas pu échanger le samedi.

Au final.

Ma première pyconfr à Rennes avait été une petite pyconfr (et au niveau des conférences que j’avais pu voir , je n’en ai pas un souvenir renversant au final). Cette PyconFR 2016 a vraiment tout d’une grande PyconFR. L’orga était top, les conférences étaient top, j’ai pu croiser des gens que j’apprécie énormément et que je ne voie vraiment pas assez souvent. Avec des salles un peu plus grandes et plus d’espaces pour se poser, tranquillement et au chaud, (parce que bon Rennes, temps pourri, pluie tout le temps, ce n’est pas vraiment possible de se poser dehors), ça aurait été une PyconFR parfaite. En tout cas merci aux orgas, merci aux orateurs, merci à ceux que j’ai pu croiser et avec qui j’ai pu échanger. Et vivement pyconfr 2017. [Bon et vivement DjangoCong 2017, retour au soleil et à la plage pour l’édition 2017 !!! Mais chut, je ne vous ai rien dit …  ]

 Posted by at 01:24

Django 1.7 et écriture de tests, petites explorations

Je me suis enfin lancé dans l’écriture d’une app django gérant les badges (ou les succès si vous préférez). L’objectif étant de pouvoir réécrire de zéro histoires de rôlistes. L’idée était de tenter de faire une vraie app django, en mode réutilisable, histoire que peut-être des gens puissent trouver intéressant de l’utiliser. Je me suis […]

DjangoIsland, parce que les poneys savent nager

Vous êtes djangonautes ? Et vous n’avez pas encore acheté votre billet pour DjangoCon Europe ? Alors peut-être que vous ne le saviez pas. Après tout, même si on a essayé de faire un maximum de com sur le sujet, on n’en fait jamais assez et il est fort possible que vous soyez passé à coté. Donc, […]

Pytong, des tongs, une plage, des présentations et des gens biens

La semaine dernière j’ai eu le plaisir d’assister (et de prendre la parole) à la première édition de Pytong, première édition, un événement organisé par Laurent et David à Toulon. Le samedi, direction la Cantine de Toulon dans les locaux de l’ISEN. La journée s’est découpée en deux parties, conférences et ligthing talk jusqu’à 15h […]

Aide mémoire virtualenv et Ubuntu

Petit aide mémoire des problèmes que j’ai pu avoir avec virtualenv, marre de devoir chercher à coup de history et de grep quand je retombe sur le soucis. En mettant à jour ma ubuntu, je suis tombé sur un problème assez ennuyeux, mes virtualenv ne voulaient plus fonctionner. L’erreur qui m’était renvoyé était tout sauf […]

Les poneys envahissent la ville rose, aka DjangoCon Toulouse, vive les pains aux chocolats !

Ce week-end avait lieu la première DjangoCon Toulouse, une rencontre django régionale au pays du cassoulet. Les festivités commençaient à 11h30 le samedi avec des LT, puis une rafale de huit conférences l’après midi, et pour finir sprint et ateliers le dimanche. Cette Djangocon est également la première Cong qui n’était pas un événement autonome […]

Des poneys avec des chapeaux ronds  aka DjangoBreizh, les poneys envahissent la bretagne

Samedi 17 novembre c’était donc la première edition des DjangoBreizh, une rencontre django locale en bretagne organisé par Exirel (bon ok, je ne suis pas tout a fait breton et pourtant j’y étais mais j’étais une exception) Le programme se découpait ainsi : matin conférence début d’après midi LT reste de l’après midi barcamp ou atelier […]

Orateurs, les rencontres django régionales ont besoin de vous !

L’un des résultats des discussions de la dernière DjangoCong fut de lancer l’idée de faire des DjangoCon régionales plus petites et qui permettraient de ne pas centraliser les attentes de toute la communauté sur un seul événement national. Et du coup d’éviter de générer de la frustration pour ceux qui n’ont pu acheter leurs billets […]