upleb.uk

Public git repos — served from a NIP-34 GRASP relay at git.upleb.uk

summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--24.md2
-rw-r--r--32.md114
-rw-r--r--65.md2
-rw-r--r--84.md61
-rw-r--r--90.md54
-rw-r--r--README.md121
6 files changed, 185 insertions, 169 deletions
diff --git a/24.md b/24.md
index dee9daa..b88d990 100644
--- a/24.md
+++ b/24.md
@@ -13,7 +13,7 @@ kind 0
13 13
14These are extra fields not specified in NIP-01 that may be present in the stringified JSON of metadata events: 14These are extra fields not specified in NIP-01 that may be present in the stringified JSON of metadata events:
15 15
16 - `display_name`: a bigger name with richer characters than `name`. Implementations should fallback to `name` when this is not available. 16 - `display_name`: an alternative, bigger name with richer characters than `name`. `name` should always be set regardless of the presence of `display_name` in the metadata.
17 - `website`: a web URL related in any way to the event author. 17 - `website`: a web URL related in any way to the event author.
18 - `banner`: an URL to a wide (~1024x768) picture to be optionally displayed in the background of a profile screen. 18 - `banner`: an URL to a wide (~1024x768) picture to be optionally displayed in the background of a profile screen.
19 19
diff --git a/32.md b/32.md
index ddd364a..f8dc002 100644
--- a/32.md
+++ b/32.md
@@ -6,50 +6,38 @@ Labeling
6 6
7`draft` `optional` `author:staab` `author:gruruya` `author:s3x-jay` 7`draft` `optional` `author:staab` `author:gruruya` `author:s3x-jay`
8 8
9A label is a `kind 1985` event that is used to label other entities. This supports a number of use cases, from distributed moderation and content recommendations to reviews and ratings. 9A label is a `kind 1985` event that is used to label other entities. This supports a number of use cases,
10including distributed moderation, collection management, license assignment, and content classification.
10 11
11Label Target 12This NIP introduces two new tags:
12----
13 13
14The label event MUST include one or more tags representing the object or objects being 14- `L` denotes a label namespace
15labeled: `e`, `p`, `a`, `r`, or `t` tags. This allows for labeling of events, people, relays, 15- `l` denotes a label
16or topics respectively. As with NIP-01, a relay hint SHOULD be included when using `e` and
17`p` tags.
18 16
19Label Tag 17Label Namespace Tag
20---- 18----
21 19
22This NIP introduces a new tag `l` which denotes a label, and a new `L` tag which denotes a label namespace. 20An `L` tag can be any string, but publishers SHOULD ensure they are unambiguous by using a well-defined namespace
23A label MUST include a mark matching an `L` tag. `L` tags refer to a tag type within nostr, or a nomenclature 21(such as an ISO standard) or reverse domain name notation.
24external to nostr defined either formally or by convention. Any string can be a namespace, but publishers SHOULD
25ensure they are unambiguous by using a well-defined namespace (such as an ISO standard) or reverse domain name notation.
26
27Namespaces starting with `#` indicate that the label target should be associated with the label's value.
28This is a way of attaching standard nostr tags to events, pubkeys, relays, urls, etc.
29
30Some examples:
31 22
32- `["l", "footstr", "#t"]` - the publisher thinks the given entity should have the `footstr` topic applied. 23`L` tags are REQUIRED in order to support searching by namespace rather than by a specific tag. The special `ugc`
33- `["l", "<pubkey>", "#p"]` - the publisher thinks the given entity is related to `<pubkey>` 24("user generated content") namespace MAY be used when the label content is provided by an end user.
34- `["l", "IT-MI", "ISO-3166-2"]` - Milano, Italy using ISO 3166-2.
35- `["l", "VI-hum", "com.example.ontology"]` - Violence toward a human being as defined by ontology.example.com.
36 25
37`L` tags containing the label namespaces MUST be included in order to support searching by 26`L` tags starting with `#` indicate that the label target should be associated with the label's value.
38namespace rather than by a specific tag. The special `ugc` ("user generated content") namespace 27This is a way of attaching standard nostr tags to events, pubkeys, relays, urls, etc.
39MAY be used when the label content is provided by an end user.
40 28
41`l` and `L` tags MAY be added to other event kinds to support self-reporting. For events 29Label Tag
42with a kind other than 1985, labels refer to the event itself. 30----
43 31
44Label Annotations 32An `l` tag's value can be any string. `l` tags MUST include a `mark` matching an `L` tag value in the same event.
45-----
46 33
47A label tag MAY include a 4th positional element detailing extra metadata about the label in question. This string 34Label Target
48should be a json-encoded object. Any key MAY be used, but the following are recommended: 35----
49 36
50- `quality` may have a value of 0 to 1. This allows for an absolute, granular scale that can be represented in any way (5 stars, color scale, etc). 37The label event MUST include one or more tags representing the object or objects being
51- `confidence` may have a value of 0 to 1. This indicates the certainty which the author has about their rating. 38labeled: `e`, `p`, `a`, `r`, or `t` tags. This allows for labeling of events, people, relays,
52- `context` may be an array of urls (including NIP-21 urls) indicating other context that should be considered when interpreting labels. 39or topics respectively. As with NIP-01, a relay hint SHOULD be included when using `e` and
40`p` tags.
53 41
54Content 42Content
55------- 43-------
@@ -57,6 +45,12 @@ Content
57Labels should be short, meaningful strings. Longer discussions, such as for a review, or an 45Labels should be short, meaningful strings. Longer discussions, such as for a review, or an
58explanation of why something was labeled the way it was, should go in the event's `content` field. 46explanation of why something was labeled the way it was, should go in the event's `content` field.
59 47
48Self-Reporting
49-------
50
51`l` and `L` tags MAY be added to other event kinds to support self-reporting. For events
52with a kind other than 1985, labels refer to the event itself.
53
60Example events 54Example events
61-------------- 55--------------
62 56
@@ -70,38 +64,61 @@ A suggestion that multiple pubkeys be associated with the `permies` topic.
70 ["l", "permies", "#t"], 64 ["l", "permies", "#t"],
71 ["p", <pubkey1>, <relay_url>], 65 ["p", <pubkey1>, <relay_url>],
72 ["p", <pubkey2>, <relay_url>] 66 ["p", <pubkey2>, <relay_url>]
73 ], 67 ]
74 "content": "",
75 ...
76} 68}
77``` 69```
78 70
79A review of a relay. 71A report flagging violence toward a human being as defined by ontology.example.com.
80 72
81```json 73```json
82{ 74{
83 "kind": 1985, 75 "kind": 1985,
84 "tags": [ 76 "tags": [
85 ["L", "com.example.ontology"], 77 ["L", "com.example.ontology"],
86 ["l", "relay/review", "com.example.ontology", "{\"quality\": 0.1}"], 78 ["l", "VI-hum", "com.example.ontology"],
87 ["r", <relay_url>] 79 ["p", <pubkey1>, <relay_url>],
80 ["p", <pubkey2>, <relay_url>]
81 ]
82}
83```
84
85A moderation suggestion for a chat event.
86
87```json
88{
89 "kind": 1985,
90 "tags": [
91 ["L", "nip28.moderation"],
92 ["l", "approve", "nip28.moderation"],
93 ["e", <kind40_event_id>, <relay_url>]
94 ],
95}
96```
97
98Assignment of a license to an event.
99
100```json
101{
102 "kind": 1985,
103 "tags": [
104 ["L", "license"],
105 ["l", "MIT", "license"],
106 ["e", <event_id>, <relay_url>]
88 ], 107 ],
89 "content": "This relay is full of mean people.",
90 ...
91} 108}
92``` 109```
93 110
94Publishers can self-label by adding `l` tags to their own non-1985 events. 111Publishers can self-label by adding `l` tags to their own non-1985 events. In this case, the kind 1 event's author
112is labeling their note as being related to Milan, Italy using ISO 3166-2.
95 113
96```json 114```json
97{ 115{
98 "kind": 1, 116 "kind": 1,
99 "tags": [ 117 "tags": [
100 ["L", "com.example.ontology"], 118 ["L", "ISO-3166-2"],
101 ["l", "IL-frd", "com.example.ontology"] 119 ["l", "IT-MI", "ISO-3166-2"]
102 ], 120 ],
103 "content": "Send me 100 sats and I'll send you 200 back", 121 "content": "It's beautiful here in Milan!",
104 ...
105} 122}
106``` 123```
107 124
@@ -124,3 +141,8 @@ Vocabularies MAY choose to fully qualify all labels within a namespace (for exam
124formal vocabularies that should not be confused with another namespace when querying 141formal vocabularies that should not be confused with another namespace when querying
125without an `L` tag. For these vocabularies, all labels SHOULD include the namespace 142without an `L` tag. For these vocabularies, all labels SHOULD include the namespace
126(rather than mixing qualified and unqualified labels). 143(rather than mixing qualified and unqualified labels).
144
145A good heuristic for whether a use case fits this NIP is whether labels would ever be unique.
146For example, many events might be labeled with a particular place, topic, or pubkey, but labels
147with specific values like "John Doe" or "3.18743" are not labels, they are values, and should
148be handled in some other way.
diff --git a/65.md b/65.md
index 939b263..cdfe9bf 100644
--- a/65.md
+++ b/65.md
@@ -53,7 +53,7 @@ This NIP allows Clients to connect directly with the most up-to-date relay set f
53 53
541. Clients SHOULD guide users to keep `kind:10002` lists small (2-4 relays). 541. Clients SHOULD guide users to keep `kind:10002` lists small (2-4 relays).
55 55
562. Clients SHOULD spread an author's `kind:10002` events to as many relays as viable. 562. Clients SHOULD spread an author's `kind:10002` event to as many relays as viable.
57 57
583. `kind:10002` events should primarily be used to advertise the user's preferred relays to others. A user's own client may use other heuristics for selecting relays for fetching data. 583. `kind:10002` events should primarily be used to advertise the user's preferred relays to others. A user's own client may use other heuristics for selecting relays for fetching data.
59 59
diff --git a/84.md b/84.md
index 89bf88b..4caab62 100644
--- a/84.md
+++ b/84.md
@@ -35,64 +35,3 @@ last value of the tag.
35### Context 35### Context
36Clients MAY include a `context` tag, useful when the highlight is a subset of a paragraph and displaying the 36Clients MAY include a `context` tag, useful when the highlight is a subset of a paragraph and displaying the
37surrounding content might be beneficial to give context to the higlight. 37surrounding content might be beneficial to give context to the higlight.
38
39### Ranges
40Clients MAY include `range` tags with the start/end indexes of where the highlight begins and finishes within
41the referenced article/tagged-event.
42
43```
44[ "range", <start-index>, <end-index> ]
45```
46
47Additionally a range with `context` as the third value of the tag MAY be added to indicate the begin/finish indexes
48of the highlight within the included `context` tag.
49
50```
51[ "range", <start-index>, <end-index>, "context" ]
52```
53
54#### Text-based nostr events' highlights
55
56Highlights of Nostr events SHOULD use the range index of the content as-is
57(e.g. NIP-23 articles include the markdown instead of computing the index from the rendered markdown).
58
59```
60[ "range", 3000, 3042 ] # highlight begins at index position 3000 of the tagged event's `.content`
61[ "range", 42, 84, "context" ] # highlight begins at index position 42 of the `context` tag's value
62```
63
64#### Non-text-based nostr events' highlights
65
66A `kind:9802` event that tags a NIP-94 event which includes a video or audio file can use ranges to
67indicate the start/end time position in seconds.
68
69#### Ranges in URL highlights
70
71When creating a highlight from a URL the range should be expressed over
72the extracted plain text of the formatted content (e.g. rendered HTML instead of including the HTML markup);
73this helps make finding the correct indexes easier on websites with markup variations on each render.
74
75e.g. `<html><body>hello, world</body></html>`
76
77Tagging `hello, world` would result in using a range tag like `["range", 0, 12 ]`.
78
79Text extraction (i.e. translation from non-plain text medium like HTML or PDF) is highly subjective and the value
80of the range should be carefully interpreted by the different clients that support this.
81
82```json
83{
84 "created_at": 1682707885,
85 "content": "while allowing creators to simply keep doing what they’re doing. Creators don’t need to be blatant shills for brands",
86 "tags": [
87 [ "r", "https://footstr.com/zapvertise/" ],
88 [ "p", "c48e29f04b482cc01ca1f9ef8c86ef8318c059e0e9353235162f080f26e14c11", "wss://relay.url", "author" ],
89 [ "context", "The Nostr zapvertising model creates a truly free market for advertisers, while allowing creators to simply keep doing what they’re doing. Creators don’t need to be blatant shills for brands, they just have to create high quality content people find valuable, and companies will naturally want to zapvertise on their posts." ]
90 [ "range", 3916, 4032 ],
91 [ "range", 74, 190, "context" ],
92 ],
93 "kind": 9802,
94 "pubkey": "fa984bd7dbb282f07e16e7ae87b26a2a7b9b90b7246a44771f0cf5ae58018f52",
95 "id": "59e5887a3cdf32d5f11edf9b8cd098c620d278514b2edde3e6d1ba8a541d262c",
96 "sig": "f2d15b8bc2csf6d198350f8df0a31dcf66d7c32ec9c54e6b3f102d579370b7de9d164d70350a5b32a2911db3b124e972bafa9a1bc8fd60c1e338903d2f6306b0"
97}
98```
diff --git a/90.md b/90.md
index 163dbd0..31447f2 100644
--- a/90.md
+++ b/90.md
@@ -67,6 +67,37 @@ All tags are optional.
67* `relays`: List of relays where Service Providers SHOULD publish responses to 67* `relays`: List of relays where Service Providers SHOULD publish responses to
68* `p`: Service Providers the customer is interested in. Other SPs MIGHT still choose to process the job 68* `p`: Service Providers the customer is interested in. Other SPs MIGHT still choose to process the job
69 69
70## Encrypted Params
71
72If the user wants to keep the input parameters a secret, they can encrypt the `i` and `param` tags with the service provider's 'p' tag and add it to the content field. Add a tag `encrypted` as tags. Encryption for private tags will use [NIP-04 - Encrypted Direct Message encryption](https://github.com/nostr-protocol/nips/blob/master/04.md), using the user's private and service provider's public key for the shared secret
73
74```json
75[
76 [ "i", "what is the capital of France? ", "text" ],
77 [ "param", "model", "LLaMA-2" ],
78 [ "param", "max_tokens", "512" ],
79 [ "param", "temperature", "0.5" ],
80 [ "param", "top-k", "50" ],
81 [ "param", "top-p", "0.7" ],
82 [ "param", "frequency_penalty", "1" ]
83
84]
85
86```
87
88This param data will be encrypted and added to the `content` field and `p` tag should be present
89
90```
91"content": "BE2Y4xvS6HIY7TozIgbEl3sAHkdZoXyLRRkZv4fLPh3R7LtviLKAJM5qpkC7D6VtMbgIt4iNcMpLtpo...",
92 "tags": [
93 ["p", "04f74530a6ede6b24731b976b8e78fb449ea61f40ff10e3d869a3030c4edc91f"],
94 ["encrypted"]
95 ]
96
97
98```
99
100
70## Job result (`kind:6000-6999`) 101## Job result (`kind:6000-6999`)
71 102
72Service providers publish job results, providing the output of the job result. They should tag the original job request event id as well as the customer's pubkey. 103Service providers publish job results, providing the output of the job result. They should tag the original job request event id as well as the customer's pubkey.
@@ -90,6 +121,27 @@ Service providers publish job results, providing the output of the job result. T
90* `amount`: millisats that the Service Provider is requesting to be paid. An optional third value can be a bolt11 invoice. 121* `amount`: millisats that the Service Provider is requesting to be paid. An optional third value can be a bolt11 invoice.
91* `i`: The original input(s) specified in the request. 122* `i`: The original input(s) specified in the request.
92 123
124## Encrypted Output
125
126If the request has encrypted params, then output should be encrypted and placed in `content` field. If the output is encrypted, then avoid including `i` tag with input-data as clear text.
127Add a tag encrypted to mark the output content as `encrypted`
128```json
129{
130 "pubkey": "<service-provider pubkey>",
131 "content": "<encrypted payload>",
132 "kind": 6xxx,
133 "tags": [
134 [ "request", "<job-request>" ],
135 [ "e", "<job-request-id>", "<relay-hint>" ],
136 [ "p", "<customer's-pubkey>" ],
137 [ "amount", "requested-payment-amount", "<optional-bolt11>" ],
138 ["encrypted"]
139
140 ]
141}
142```
143
144
93## Job feedback 145## Job feedback
94Service providers can give feedback about a job back to the customer. 146Service providers can give feedback about a job back to the customer.
95 147
@@ -110,6 +162,8 @@ Service providers can give feedback about a job back to the customer.
110* `amount` tag: as defined in the [Job Result](#job-result) section. 162* `amount` tag: as defined in the [Job Result](#job-result) section.
111* `status` tag: Service Providers SHOULD indicate what this feedback status refers to. [Appendix 1](#appendix-1-job-feedback-status) defines status. Extra human-readable information can be added as an extra argument. 163* `status` tag: Service Providers SHOULD indicate what this feedback status refers to. [Appendix 1](#appendix-1-job-feedback-status) defines status. Extra human-readable information can be added as an extra argument.
112 164
165* NOTE: If the input params requires input to be encryped, then `content` field will have encrypted payload with `p` tag as key.
166
113### Job feedback status 167### Job feedback status
114 168
115| status | description | 169| status | description |
diff --git a/README.md b/README.md
index 36dfada..483056d 100644
--- a/README.md
+++ b/README.md
@@ -7,12 +7,12 @@ They exist to document what may be implemented by [Nostr](https://github.com/nos
7 7
8- [List](#list) 8- [List](#list)
9- [Event Kinds](#event-kinds) 9- [Event Kinds](#event-kinds)
10 - [Event Kind Ranges](#event-kind-ranges)
11- [Message Types](#message-types) 10- [Message Types](#message-types)
12 - [Client to Relay](#client-to-relay) 11 - [Client to Relay](#client-to-relay)
13 - [Relay to Client](#relay-to-client) 12 - [Relay to Client](#relay-to-client)
14- [Standardized Tags](#standardized-tags) 13- [Standardized Tags](#standardized-tags)
15- [Criteria for acceptance of NIPs](#criteria-for-acceptance-of-nips) 14- [Criteria for acceptance of NIPs](#criteria-for-acceptance-of-nips)
15- [Mailing Lists](#mailing-lists)
16- [License](#license) 16- [License](#license)
17 17
18--- 18---
@@ -74,65 +74,66 @@ They exist to document what may be implemented by [Nostr](https://github.com/nos
74- [NIP-99: Classified Listings](99.md) 74- [NIP-99: Classified Listings](99.md)
75 75
76## Event Kinds 76## Event Kinds
77 77| kind | description | NIP |
78| kind | description | NIP | 78| ------------- | -------------------------- | ----------- |
79| ------- | -------------------------- | ----------- | 79| `0` | Metadata | [1](01.md) |
80| `0` | Metadata | [1](01.md) | 80| `1` | Short Text Note | [1](01.md) |
81| `1` | Short Text Note | [1](01.md) | 81| `2` | Recommend Relay | |
82| `2` | Recommend Relay | | 82| `3` | Contacts | [2](02.md) |
83| `3` | Contacts | [2](02.md) | 83| `4` | Encrypted Direct Messages | [4](04.md) |
84| `4` | Encrypted Direct Messages | [4](04.md) | 84| `5` | Event Deletion | [9](09.md) |
85| `5` | Event Deletion | [9](09.md) | 85| `6` | Repost | [18](18.md) |
86| `6` | Repost | [18](18.md) | 86| `7` | Reaction | [25](25.md) |
87| `7` | Reaction | [25](25.md) | 87| `8` | Badge Award | [58](58.md) |
88| `8` | Badge Award | [58](58.md) | 88| `16` | Generic Repost | [18](18.md) |
89| `16` | Generic Repost | [18](18.md) | 89| `40` | Channel Creation | [28](28.md) |
90| `40` | Channel Creation | [28](28.md) | 90| `41` | Channel Metadata | [28](28.md) |
91| `41` | Channel Metadata | [28](28.md) | 91| `42` | Channel Message | [28](28.md) |
92| `42` | Channel Message | [28](28.md) | 92| `43` | Channel Hide Message | [28](28.md) |
93| `43` | Channel Hide Message | [28](28.md) | 93| `44` | Channel Mute User | [28](28.md) |
94| `44` | Channel Mute User | [28](28.md) | 94| `1063` | File Metadata | [94](94.md) |
95| `1063` | File Metadata | [94](94.md) | 95| `1311` | Live Chat Message | [53](53.md) |
96| `1311` | Live Chat Message | [53](53.md) | 96| `1040` | OpenTimestamps | [03](03.md) |
97| `1040` | OpenTimestamps | [03](03.md) | 97| `1971` | Problem Tracker | [1971](https://github.com/nostrocket/NIPS/blob/main/Problems.md) |
98| `1971` | Problem Tracker | [1971](https://github.com/nostrocket/NIPS/blob/main/Problems.md) | 98| `1984` | Reporting | [56](56.md) |
99| `1984` | Reporting | [56](56.md) | 99| `1985` | Label | [32](32.md) |
100| `1985` | Label | [32](32.md) | 100| `4550` | Community Post Approval | [72](72.md) |
101| `4550` | Community Post Approval | [72](72.md) | 101| `5000`-`5999` | Job Request | [90](90.md) |
102| `7000` | Job Feedback | [90](90.md) | 102| `6000`-`6999` | Job Result | [90](90.md) |
103| `9041` | Zap Goal | [75](75.md) | 103| `7000` | Job Feedback | [90](90.md) |
104| `9734` | Zap Request | [57](57.md) | 104| `9041` | Zap Goal | [75](75.md) |
105| `9735` | Zap | [57](57.md) | 105| `9734` | Zap Request | [57](57.md) |
106| `9802` | Highlights | [84](84.md) | 106| `9735` | Zap | [57](57.md) |
107| `10000` | Mute List | [51](51.md) | 107| `9802` | Highlights | [84](84.md) |
108| `10001` | Pin List | [51](51.md) | 108| `10000` | Mute List | [51](51.md) |
109| `10002` | Relay List Metadata | [65](65.md) | 109| `10001` | Pin List | [51](51.md) |
110| `13194` | Wallet Info | [47](47.md) | 110| `10002` | Relay List Metadata | [65](65.md) |
111| `22242` | Client Authentication | [42](42.md) | 111| `13194` | Wallet Info | [47](47.md) |
112| `23194` | Wallet Request | [47](47.md) | 112| `22242` | Client Authentication | [42](42.md) |
113| `23195` | Wallet Response | [47](47.md) | 113| `23194` | Wallet Request | [47](47.md) |
114| `24133` | Nostr Connect | [46](46.md) | 114| `23195` | Wallet Response | [47](47.md) |
115| `27235` | HTTP Auth | [98](98.md) | 115| `24133` | Nostr Connect | [46](46.md) |
116| `30000` | Categorized People List | [51](51.md) | 116| `27235` | HTTP Auth | [98](98.md) |
117| `30001` | Categorized Bookmark List | [51](51.md) | 117| `30000` | Categorized People List | [51](51.md) |
118| `30008` | Profile Badges | [58](58.md) | 118| `30001` | Categorized Bookmark List | [51](51.md) |
119| `30009` | Badge Definition | [58](58.md) | 119| `30008` | Profile Badges | [58](58.md) |
120| `30017` | Create or update a stall | [15](15.md) | 120| `30009` | Badge Definition | [58](58.md) |
121| `30018` | Create or update a product | [15](15.md) | 121| `30017` | Create or update a stall | [15](15.md) |
122| `30023` | Long-form Content | [23](23.md) | 122| `30018` | Create or update a product | [15](15.md) |
123| `30024` | Draft Long-form Content | [23](23.md) | 123| `30023` | Long-form Content | [23](23.md) |
124| `30078` | Application-specific Data | [78](78.md) | 124| `30024` | Draft Long-form Content | [23](23.md) |
125| `30311` | Live Event | [53](53.md) | 125| `30078` | Application-specific Data | [78](78.md) |
126| `30315` | User Statuses | [38](38.md) | 126| `30311` | Live Event | [53](53.md) |
127| `30402` | Classified Listing | [99](99.md) | 127| `30315` | User Statuses | [38](38.md) |
128| `30403` | Draft Classified Listing | [99](99.md) | 128| `30402` | Classified Listing | [99](99.md) |
129| `31922` | Date-Based Calendar Event | [52](52.md) | 129| `30403` | Draft Classified Listing | [99](99.md) |
130| `31923` | Time-Based Calendar Event | [52](52.md) | 130| `31922` | Date-Based Calendar Event | [52](52.md) |
131| `31924` | Calendar | [52](52.md) | 131| `31923` | Time-Based Calendar Event | [52](52.md) |
132| `31925` | Calendar Event RSVP | [52](52.md) | 132| `31924` | Calendar | [52](52.md) |
133| `31989` | Handler recommendation | [89](89.md) | 133| `31925` | Calendar Event RSVP | [52](52.md) |
134| `31990` | Handler information | [89](89.md) | 134| `31989` | Handler recommendation | [89](89.md) |
135| `34550` | Community Definition | [72](72.md) | 135| `31990` | Handler information | [89](89.md) |
136| `34550` | Community Definition | [72](72.md) |
136 137
137## Message types 138## Message types
138 139