Projet

Général

Profil

Development #9324

Permission needs unique index and partial unique indexes to prevent duplicate due to get_or_create()

Ajouté par Benjamin Dauvergne il y a plus de 8 ans. Mis à jour il y a plus de 6 ans.

Statut:
Fermé
Priorité:
Normal
Assigné à:
Catégorie:
-
Version cible:
Début:
14 décembre 2015
Echéance:
% réalisé:

0%

Temps estimé:
Patch proposed:
Non
Planning:

Description

get_or_create() is safe only if filtered keys covers at least a unique index (partial or not).

Historique

#1

Mis à jour par Benjamin Dauvergne il y a plus de 8 ans

  • Statut changé de Nouveau à Solution déployée

To find and remove existing duplicates:

delete from a2_rbac_permission where id in (select p.id from a2_rbac_role_permissions as rp right outer join a2_rbac_permission p on rp.permission_id = p.id left outer join a2_rbac_role as r on r.admin_scope_ct_id = 66 and r.admin_scope_id = p.id where rp.id is null and r.id is null);

commit 8a23dc8be0f9b1dd0995da6479bf439b9fc7c1e2
Author: Benjamin Dauvergne <bdauvergne@entrouvert.com>
Date:   Mon Dec 14 14:46:04 2015 +0100

    a2_rbac: add a partial index to prevent duplicate permissions (fixes #9234)

#2

Mis à jour par Benjamin Dauvergne il y a plus de 8 ans

Le admin_scope_ct_id dans ma requête est à chercher dans django_content_type, c'est l'id du modèle a2_rbac.permission.

#3

Mis à jour par Benjamin Dauvergne il y a plus de 6 ans

  • Statut changé de Solution déployée à Fermé

Formats disponibles : Atom PDF