Software / code / prosody
Comparison
teal-src/plugins/muc/muc.lib.d.tl @ 12891:93ce4244d433
MUC: Start on a Teal description of MUC rooms
Started as part of a documentation project for the MUC API
| author | Kim Alvefur <zash@zash.se> |
|---|---|
| date | Mon, 20 Feb 2023 15:08:06 +0100 |
| child | 12892:d788714fcf21 |
comparison
equal
deleted
inserted
replaced
| 12890:05b3b3dc7326 | 12891:93ce4244d433 |
|---|---|
| 1 local Stanza = require "util.stanza".stanza_t | |
| 2 | |
| 3 local record Room | |
| 4 jid : string | |
| 5 | |
| 6 enum Affiliation | |
| 7 "outcast" | |
| 8 "none" | |
| 9 "member" | |
| 10 "admin" | |
| 11 "owner" | |
| 12 end | |
| 13 | |
| 14 enum Role | |
| 15 "none" | |
| 16 "visitor" | |
| 17 "participant" | |
| 18 "moderator" | |
| 19 end | |
| 20 | |
| 21 record Occupant | |
| 22 bare_jid : string | |
| 23 nick : string | |
| 24 sessions : { string : Stanza } | |
| 25 role : Role | |
| 26 jid : string | |
| 27 end | |
| 28 | |
| 29 -- Private properties | |
| 30 _jid_nick : { string : string } | |
| 31 _occupants : { string : Occupant } | |
| 32 _data : { string : any } | |
| 33 _affiliations : { string : Affiliation } | |
| 34 _affiliation_data : { string : { string : any } } | |
| 35 | |
| 36 -- Occupant methods | |
| 37 get_occupant_jid : function (Room, real_jid : string) : string | |
| 38 new_occupant : function (Room, bare_real_jid : string, nick : string) : Occupant | |
| 39 get_occupant_by_nick : function (Room, nick : string) : Occupant | |
| 40 type OccupantIterator = function ({string:Occupant}, occupant_jid : string) : string, Occupant | |
| 41 each_occupant : function (Room, read_only : boolean) : OccupantIterator, {string:Occupant}, nil | |
| 42 has_occupant : function (Room) : boolean | |
| 43 get_occupant_by_real_jid : function (Room, real_jid : string) : Occupant | |
| 44 save_occupant :function (Room, Occupant) : Occupant | |
| 45 | |
| 46 -- Affiliation methods | |
| 47 type AffiliationIterator = function (any, jid : string) : string, Affiliation | |
| 48 get_affiliation : function (Room, jid : string) : Affiliation | |
| 49 each_affiliation : function (Room, Affiliation) : AffiliationIterator, nil, nil | |
| 50 set_affiliation : function (Room, jid : string, Affiliation, reason : string, data : { string : any }) : boolean, string, string, string -- ok + error tripplet | |
| 51 get_affiliation_data : function (Room, jid : string, key : string) : any | |
| 52 set_affiliation_data : function (Room, jid : string, key : string, value : any) : boolean | |
| 53 get_registered_nick : function (Room, jid : string) : string | |
| 54 get_registered_jid : function (Room, nick : string) : string | |
| 55 | |
| 56 -- Role methods | |
| 57 get_default_role : function (Room, Affiliation) : Role, integer | |
| 58 get_role : function (Room, nick : string) : Role | |
| 59 may_set_role : function (Room, actor : string, Occupant, Role) : boolean | |
| 60 set_role : function (Room, actor : string, occupant_jid : string, Role, reason : string) : boolean, string, string, string | |
| 61 | |
| 62 -- Routing input, generally handled by mod_muc and hooked up to Prosody routing events | |
| 63 handle_first_presence : function (Room, table, Stanza) : boolean | |
| 64 handle_normal_presence : function (Room, table, Stanza) : boolean | |
| 65 handle_presence_to_room : function (Room, table, Stanza) : boolean | |
| 66 handle_presence_to_occupant : function (Room, table, Stanza) : boolean | |
| 67 handle_message_to_room : function (Room, table, Stanza) : boolean | |
| 68 handle_message_to_occupant : function (Room, table, Stanza) : boolean | |
| 69 handle_groupchat_to_room : function (Room, table, Stanza) : boolean | |
| 70 handle_iq_to_occupant : function (Room, table, Stanza) : boolean | |
| 71 handle_disco_info_get_query : function (Room, table, Stanza) : boolean | |
| 72 handle_disco_items_get_query : function (Room, table, Stanza) : boolean | |
| 73 handle_admin_query_set_command : function (Room, table, Stanza) : boolean | |
| 74 handle_admin_query_get_command : function (Room, table, Stanza) : boolean | |
| 75 handle_owner_query_get_to_room : function (Room, table, Stanza) : boolean | |
| 76 handle_owner_query_set_to_room : function (Room, table, Stanza) : boolean | |
| 77 handle_mediated_invite : function (Room, table, Stanza) : boolean | |
| 78 handle_mediated_decline : function (Room, table, Stanza) : boolean | |
| 79 handle_role_request : function (Room, table, Stanza) : boolean | |
| 80 handle_register_iq : function (Room, table, Stanza) : boolean | |
| 81 handle_kickable : function (Room, table, Stanza) : boolean | |
| 82 | |
| 83 -- Routing output | |
| 84 broadcast : function (Room, Stanza, function (nick : string, Occupant) : boolean) | |
| 85 broadcast_message : function (Room, Stanza) : boolean | |
| 86 route_stanza : function (Room, Stanza) | |
| 87 route_to_occupant : function (Room, Occupant, Stanza) | |
| 88 | |
| 89 -- Sending things to someone joining | |
| 90 publicise_occupant_status : function (Room, Occupant, x : Stanza, nick : string, actor : string, reason : string, prev_role : Role, force_unavailable : boolean, recipient : Occupant) | |
| 91 send_occupant_list : function (Room, to : string, filter : function (occupant_jid : string, Occupant) : boolean) | |
| 92 send_history : function (Room, Stanza) | |
| 93 send_subject : function (Room, to : string, time : number) | |
| 94 | |
| 95 respond_to_probe : function (Room, table, Stanza, Occupant) | |
| 96 | |
| 97 -- Constructors for various answer stanzas | |
| 98 get_disco_info : function (Room, Stanza) : Stanza | |
| 99 get_disco_items : function (Room, Stanza) : Stanza | |
| 100 | |
| 101 build_item_list : function (Room, Occupant, Stanza, is_anonymous : boolean, nick : string, actor_nick : string, actor_jid : string, reason : string) : Stanza | |
| 102 build_unavailable_presence : function (Room, from_muc_jid : string, to_jid : string) : Stanza | |
| 103 | |
| 104 -- Form handling | |
| 105 send_form : function (Room, table, Stanza) | |
| 106 get_form_layout : function (Room, actor : string) : table | |
| 107 process_form : function (Room, table, Stanza) : boolean | |
| 108 | |
| 109 -- Properties and configuration | |
| 110 get_name : function (Room) : string | |
| 111 set_name : function (Room, string) : boolean | |
| 112 get_description : function (Room) : string | |
| 113 set_description : function (Room, string) : boolean | |
| 114 get_language : function (Room) : string | |
| 115 set_language : function (Room, string) : boolean | |
| 116 get_hidden : function (Room) : boolean | |
| 117 set_hidden : function (Room, boolean) | |
| 118 get_public : function (Room) : boolean | |
| 119 set_public : function (Room, boolean) | |
| 120 get_password : function (Room) : string | |
| 121 set_password : function (Room, string) : boolean | |
| 122 get_members_only : function (Room) : boolean | |
| 123 set_members_only : function (Room, boolean) : boolean | |
| 124 get_allow_member_invites : function (Room) : boolean | |
| 125 set_allow_member_invites : function (Room, boolean) : boolean | |
| 126 get_moderated : function (Room) : boolean | |
| 127 set_moderated : function (Room, boolean) : boolean | |
| 128 get_persistent : function (Room) : boolean | |
| 129 set_persistent : function (Room, boolean) : boolean | |
| 130 get_changesubject : function (Room) : boolean | |
| 131 set_changesubject : function (Room, boolean) : boolean | |
| 132 get_subject : function (Room) : string | |
| 133 set_subject : function (Room, string) : boolean | |
| 134 get_historylength : function (Room) : integer | |
| 135 set_historylength : function (Room, integer) : boolean | |
| 136 get_presence_broadcast : function (Room) : { Role : boolean } | |
| 137 set_presence_broadcast : function (Room, { Role : boolean }) : boolean | |
| 138 | |
| 139 is_anonymous_for : function (Room, jid : string) : boolean | |
| 140 get_salt : function (Room) : string | |
| 141 get_occupant_id : function (Room, Occupant) | |
| 142 | |
| 143 -- Room teardown | |
| 144 clear : function (Room, x : Stanza) | |
| 145 destroy : function (Room, newjid : string, reason : string, password : string) : boolean | |
| 146 | |
| 147 -- Room state persistence | |
| 148 record FrozenRoom | |
| 149 _jid : string | |
| 150 _data : { string : any } | |
| 151 _affiliation_data : { string : { string : any } } | |
| 152 -- { string : Affiliation } | |
| 153 end | |
| 154 | |
| 155 record StateEntry | |
| 156 bare_jid : string | |
| 157 role : Role | |
| 158 jid : string | |
| 159 end | |
| 160 | |
| 161 save : function (Room, forced : boolean, savestate : boolean) : boolean | |
| 162 freeze : function (Room, live : boolean) : FrozenRoom, { string : StateEntry } | |
| 163 end |