Comparison

mod_privilege/README.markdown @ 4937:3ddab718f717

mod_privilege: update to v0.4: - now the namespace "urn:xmpp:privilege:2" is exclusively used - IQ permission implementation - README update roster pushes are not implemented yet
author Goffi <goffi@goffi.org>
date Wed, 11 May 2022 12:43:26 +0200
parent 1992:8dda3d7d616f
comparison
equal deleted inserted replaced
4912:b45c23ce24ba 4937:3ddab718f717
1 --- 1 ---
2 labels: 2 labels:
3 - 'Stage-Alpha' 3 - 'Stage-Beta'
4 summary: 'XEP-0356 (Privileged Entity) implementation' 4 summary: 'XEP-0356 (Privileged Entity) implementation'
5 ... 5 ...
6 6
7 Introduction 7 Introduction
8 ============ 8 ============
9 9
10 Privileged Entity is an extension which allows entity/component to have 10 Privileged Entity is an extension which allows entity/component to have
11 privileged access to server (set/get roster, send message on behalf of 11 privileged access to server (set/get roster, send message on behalf of server,
12 server, access presence informations). It can be used to build services 12 send IQ stanza on behalf of user, access presence information). It can be used
13 independently of server (e.g.: PEP service). 13 to build services independently of server (e.g.: PEP service).
14 14
15 Details 15 Details
16 ======= 16 =======
17 17
18 You can have all the details by reading the 18 You can have all the details by reading the
19 [XEP-0356](http://xmpp.org/extensions/xep-0356.html). 19 [XEP-0356](http://xmpp.org/extensions/xep-0356.html).
20
21 Only the latest version of the XEP is implemented (using namespace
22 `urn:xmpp:privilege:2`), if your component use an older version, please update.
23
24 Note that roster permission is not fully implemented yet, roster pushes are not yet sent
25 to privileged entity.
20 26
21 Usage 27 Usage
22 ===== 28 =====
23 29
24 To use the module, like usual add **"privilege"** to your 30 To use the module, like usual add **"privilege"** to your
31 "privilege"; 37 "privilege";
32 } 38 }
33 39
34 [...] 40 [...]
35 41
36 Component "youcomponent.yourdomain.tld" 42 Component "pubsub.yourdomain.tld"
37 component_secret = "yourpassword" 43 component_secret = "yourpassword"
38 modules_enabled = {"privilege"} 44 modules_enabled = {"privilege"}
39 45
40 then specify privileged entities **in your host section** like that: 46 then specify privileged entities **in your host section** like that:
41 47
49 ["juliet@capulet.lit"] = { 55 ["juliet@capulet.lit"] = {
50 roster = "both"; 56 roster = "both";
51 message = "outgoing"; 57 message = "outgoing";
52 presence = "roster"; 58 presence = "roster";
53 }, 59 },
60 ["pubsub.yourdomain.tld"] = {
61 roster = "get";
62 message = "outgoing";
63 presence = "roster";
64 iq = {
65 ["http://jabber.org/protocol/pubsub"] = "set";
66 };
67 },
54 } 68 }
55 69
56 Here *romeo@montaigu.lit* can **get** roster of anybody on the host, and 70 Here *romeo@montaigu.lit* can **get** roster of anybody on the host, and will
57 will **have presence for any user** of the host, while 71 **have presence for any user** of the host, while *juliet@capulet.lit* can
58 *juliet@capulet.lit* can **get** and **set** a roster, **send messages** 72 **get** and **set** a roster, **send messages** on behalf of the server, and
59 on the behalf of the server, and **access presence of anybody linked to 73 **access presence of anybody linked to the host** (not only people on the
60 the host** (not only people on the server, but also people in rosters of 74 server, but also people in rosters of users of the server).
61 users of the server).
62 75
63 **/! Be extra careful when you give a permission to an entity/component, 76 *pubsub.yourdomain.tld* is a Pubsub/PEP component which can **get** roster of
64 it's a powerful access, only do it if you absoly trust the 77 anybody on the host, **send messages** on the behalf of the server, **access
65 component/entity, and you know where the software is coming from** 78 presence of anybody linked to the host**, and **send IQ stanza of type "set" for
79 the namespace "http://jabber.org/protocol/pubsub"** (this can be used to
80 implement XEP-0376 "Pubsub Account Management").
81
82 **/!\\ Be extra careful when you give a permission to an entity/component, it's
83 a powerful access, only do it if you absolutely trust the component/entity, and
84 you know where the software is coming from**
66 85
67 Configuration 86 Configuration
68 ============= 87 =============
88
89 roster
90 ------
69 91
70 All the permissions give access to all accounts of the virtual host. 92 All the permissions give access to all accounts of the virtual host.
71 93
72 -------- ------------------------------------------------ ---------------------- 94 -------- ------------------------------------------------ ----------------------
73 roster none *(default)* No access to rosters 95 roster none *(default)* No access to rosters
74 get Allow **read** access to rosters 96 get Allow **read** access to rosters
75 set Allow **write** access to rosters 97 set Allow **write** access to rosters
76 both Allow **read** and **write** access to rosters 98 both Allow **read** and **write** access to rosters
77 -------- ------------------------------------------------ ---------------------- 99 -------- ------------------------------------------------ ----------------------
100
101 Note that roster implementation is incomplete at the moment, roster pushes are not yet
102 send to privileged entity.
78 103
79 message 104 message
80 ------- 105 -------
81 106
82 ------------------ ------------------------------------------------------------ 107 ------------------ ------------------------------------------------------------
90 ------------------ ------------------------------------------------------------------------------------------------ 115 ------------------ ------------------------------------------------------------------------------------------------
91 none *(default)* Do not have extra presence information 116 none *(default)* Do not have extra presence information
92 managed\_entity Receive presence stanzas (except subscriptions) from host users 117 managed\_entity Receive presence stanzas (except subscriptions) from host users
93 roster Receive all presence stanzas (except subsciptions) from host users and people in their rosters 118 roster Receive all presence stanzas (except subsciptions) from host users and people in their rosters
94 ------------------ ------------------------------------------------------------------------------------------------ 119 ------------------ ------------------------------------------------------------------------------------------------
120
121 iq
122 --
123
124 IQ permission is a table mapping allowed namespaces to allowed stanza type. When
125 a namespace is specified, IQ stanza of the specified type (see below) can be
126 sent if and only if the first child element of the IQ stanza has the specified
127 namespace. See https://xmpp.org/extensions/xep-0356.html#iq for details.
128
129 Allowed stanza type:
130
131 -------- -------------------------------------------
132 get Allow IQ stanza of type **get**
133 set Allow IQ stanza of type **set**
134 both Allow IQ stanza of type **get** and **set**
135 -------- -------------------------------------------
95 136
96 Compatibility 137 Compatibility
97 ============= 138 =============
98 139
99 If you use it with Prosody 0.9 and with a component, you need to patch 140 If you use it with Prosody 0.9 and with a component, you need to patch
116 157
117 Then, at the root of prosody, enter: 158 Then, at the root of prosody, enter:
118 159
119 `patch -p1 < /tmp/component.patch` 160 `patch -p1 < /tmp/component.patch`
120 161
121 ----- ---------------------------------------------------- 162 ----- --------------------------------------------------
163 trunk Works
164 0.12 Works
165 0.11 Works
122 0.10 Works 166 0.10 Works
123 0.9 Need a patched core/mod\_component.lua (see above) 167 0.9 Need a patched core/mod\_component.lua (see above)
124 ----- ---------------------------------------------------- 168 ----- --------------------------------------------------
125 169
126 Note 170 Note
127 ==== 171 ====
128 172
129 This module is often used with mod\_delegation (c.f. XEP for more 173 This module is often used with mod\_delegation (c.f. XEP for more details)
130 details)