annotate sat_pubsub/container.py @ 330:82d1259b3e36

backend, pgsql storage: better items/notification handling, various fixes: - replaced const.VAL_AMODEL_ROSTER by const.VAL_AMODEL_PUBLISHER_ROSTER to follow change in pgsql schema - implemented whitelist access model - fixed bad access check during items retrieval (access was checked on recipient instead of requestor/sender) - getItemsData and notification filtering now use inline callbacks: this make these complexe workflows far mor easy to read, and clarity is imperative in these security critical sections. - publisher-roster access model now need to have only one owner, else it will fail. The idea is to use this model only when owner=publisher, else there is ambiguity on the roster to use to check access - replaced getNodeOwner by node.getOwners, as a node can have several owners - notifications filtering has been fixed in a similar way - psql: simplified withPEP method, pep_table argument is actually not needed - removed error.NotInRoster: error.Forbidden is used instead - notifications now notify all the owners, not only the first one
author Goffi <goffi@goffi.org>
date Sun, 26 Mar 2017 20:52:32 +0200
parents 54d90c73b8b5
children a772f7dac930
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
317
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
1 #!/usr/bin/python
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
2 #-*- coding: utf-8 -*-
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
3
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
4 # Copyright (C) 2016 Jérôme Poisson (goffi@goffi.org)
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
5
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
6 # This program is free software: you can redistribute it and/or modify
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
7 # it under the terms of the GNU Affero General Public License as published by
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
8 # the Free Software Foundation, either version 3 of the License, or
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
9 # (at your option) any later version.
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
10
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
11 # This program is distributed in the hope that it will be useful,
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
14 # GNU Affero General Public License for more details.
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
15
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
16 # You should have received a copy of the GNU Affero General Public License
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
17 # along with this program. If not, see <http://www.gnu.org/licenses/>.
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
18
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
19
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
20 from collections import namedtuple
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
21
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
22
322
54d90c73b8b5 mam: various improvments:
Goffi <goffi@goffi.org>
parents: 317
diff changeset
23 ItemData = namedtuple('ItemData', ('item', 'access_model', 'config', 'categories', 'date'))
317
34adc4a8aa64 new container module, with an ItemData container:
Goffi <goffi@goffi.org>
parents:
diff changeset
24 ItemData.__new__.__defaults__ = (None,) * (len(ItemData._fields) - 1) # Only item is mandatory