comparison mod_client_proxy/README.markdown @ 3098:a81456a13797

mod_client_proxy: a Jabber Address Translation implementation
author Jonas Wielicki <jonas@wielicki.name>
date Sun, 03 Jun 2018 13:55:10 +0200 (2018-06-03)
parents
children f04dbfad5407
comparison
equal deleted inserted replaced
3097:c7f4e3987ed0 3098:a81456a13797
1 ---
2 labels:
3 - 'Stage-Alpha'
4 summary: 'Proxy multiple client resources behind a single component'
5 ...
6
7 What it does
8 ============
9
10 This module must be used as a component. For example:
11
12 Component "proxy.domain.example" "client_proxy"
13 target_address = "some-user@some-domain.example"
14
15 All IQ requests against the proxy host (in the above example:
16 proxy.domain.example) are sent to a random resource of the target address (in
17 the above example: some-user@some-domain.example). The entity behind the
18 target address is called the "implementing client".
19
20 The IQ requests are JAT-ed (JAT: Jabber Address Translation) so that when the
21 implementing client answers the IQ request, it is sent back to the component,
22 which reverts the translation and routes the reply back to the user.
23
24 Let us assume that user@some-domain.exmaple sends a request. The
25 proxy.domain.example component has the client_proxy module loaded and proxies to
26 some-user@some-domain.example. some-user@some-domain.example has two resources,
27 /a and /b.
28
29 user -> component:
30 <iq type='get' id='1234' to='proxy.domain.example' from='user@some-domain.example/abc'>
31 component -> implementing client:
32 <iq type='get' id='1234' to='some-user@some-domain.example/a' from='proxy.domain.example/encoded-from'>
33 implementing client -> component:
34 <iq type='result' id='1234' to='proxy.domain.example/encoded-from' from='some-user@some-domain.example/a'>
35 component -> user:
36 <iq type='result' id='1234' to='user@some-domain.example/abc' from='proxy.domain.example'>
37
38 The encoded-from resource used in the exchange between the proxy component
39 and the implementing client is an implementation-defined string which allows
40 the proxy component to revert the JAT.
41
42
43 Use cases
44 =========
45
46 * Implementation of services within clients instead of components, thus making
47 use of the more advanced authentication features.
48 * General evilness
49
50
51 Configuration
52 =============
53
54 To use this module, it needs to be loaded on a component:
55
56 Component "proxy.yourdomain.example" "client_proxy"
57 target_address = "implementation@yourdomain.example"
58
59 It will then send a subscription request to implementation@yourdomain.example
60 which MUST be accepted: this is required so that the component can detect the
61 resources to which IQ requests can be dispatched.
62
63
64 Limitations
65 ===========
66
67 * It does not handle presence or message stanzas.
68 * It does not allow the implementing client to initiate IQ requests