aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llmessage/llinstantmessage.h
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llmessage/llinstantmessage.h')
-rw-r--r--linden/indra/llmessage/llinstantmessage.h327
1 files changed, 327 insertions, 0 deletions
diff --git a/linden/indra/llmessage/llinstantmessage.h b/linden/indra/llmessage/llinstantmessage.h
new file mode 100644
index 0000000..a7074a2
--- /dev/null
+++ b/linden/indra/llmessage/llinstantmessage.h
@@ -0,0 +1,327 @@
1/**
2 * @file llinstantmessage.h
3 * @brief Constants and declarations used by instant messages.
4 *
5 * Copyright (c) 2002-2007, Linden Research, Inc.
6 *
7 * The source code in this file ("Source Code") is provided by Linden Lab
8 * to you under the terms of the GNU General Public License, version 2.0
9 * ("GPL"), unless you have obtained a separate licensing agreement
10 * ("Other License"), formally executed by you and Linden Lab. Terms of
11 * the GPL can be found in doc/GPL-license.txt in this distribution, or
12 * online at http://secondlife.com/developers/opensource/gplv2
13 *
14 * There are special exceptions to the terms and conditions of the GPL as
15 * it is applied to this Source Code. View the full text of the exception
16 * in the file doc/FLOSS-exception.txt in this software distribution, or
17 * online at http://secondlife.com/developers/opensource/flossexception
18 *
19 * By copying, modifying or distributing this software, you acknowledge
20 * that you have read and understood your obligations described above,
21 * and agree to abide by those obligations.
22 *
23 * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
24 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
25 * COMPLETENESS OR PERFORMANCE.
26 */
27
28#ifndef LL_LLINSTANTMESSAGE_H
29#define LL_LLINSTANTMESSAGE_H
30
31#include "llhost.h"
32#include "lluuid.h"
33#include "llsd.h"
34#include "llmemory.h"
35#include "v3math.h"
36
37class LLMessageSystem;
38
39// The ImprovedInstantMessage only supports 8 bits in the "Dialog"
40// field, so don't go past the byte boundary
41enum EInstantMessage
42{
43 // default. ID is meaningless, nothing in the binary bucket.
44 IM_NOTHING_SPECIAL = 0,
45
46 // pops a messagebox with a single OK button
47 IM_MESSAGEBOX = 1,
48
49 // pops a countdown messagebox with a single OK button
50 // IM_MESSAGEBOX_COUNTDOWN = 2,
51
52 // You've been invited to join a group.
53 // ID is the group id.
54
55 // The binary bucket contains a null terminated string
56 // representation of the officer/member status and join cost for
57 // the invitee. (bug # 7672) The format is 1 byte for
58 // officer/member (O for officer, M for member), and as many bytes
59 // as necessary for cost.
60 IM_GROUP_INVITATION = 3,
61
62 // Inventory offer.
63 // ID is the transaction id
64 // Binary bucket is a list of inventory uuid and type.
65 IM_INVENTORY_OFFERED = 4,
66 IM_INVENTORY_ACCEPTED = 5,
67 IM_INVENTORY_DECLINED = 6,
68
69 // Group vote
70 // Name is name of person who called vote.
71 // ID is vote ID used for internal tracking
72 IM_GROUP_VOTE = 7,
73
74 // Group message
75 // This means that the message is meant for everyone in the
76 // agent's group. This will result in a database query to find all
77 // participants and start an im session.
78 IM_GROUP_MESSAGE_DEPRECATED = 8,
79
80 // Task inventory offer.
81 // ID is the transaction id
82 // Binary bucket is a (mostly) complete packed inventory item
83 IM_TASK_INVENTORY_OFFERED = 9,
84 IM_TASK_INVENTORY_ACCEPTED = 10,
85 IM_TASK_INVENTORY_DECLINED = 11,
86
87 // Copied as pending, type LL_NOTHING_SPECIAL, for new users
88 // used by offline tools
89 IM_NEW_USER_DEFAULT = 12,
90
91 //
92 // session based messaging - the way that people usually actually
93 // communicate with each other.
94 //
95
96 // Start a session, or add users to a session.
97 IM_SESSION_ADD = 13,
98
99 // Start a session, but don't prune offline users
100 IM_SESSION_OFFLINE_ADD = 14,
101
102 // start a session with your gruop
103 IM_SESSION_GROUP_START = 15,
104
105 // start a session without a calling card (finder or objects)
106 IM_SESSION_CARDLESS_START = 16,
107
108 // send a message to a session.
109 IM_SESSION_SEND = 17,
110
111 // leave a session
112 IM_SESSION_DROP = 18,
113
114 // an instant message from an object - for differentiation on the
115 // viewer, since you can't IM an object yet.
116 IM_FROM_TASK = 19,
117
118 // sent an IM to a busy user, this is the auto response
119 IM_BUSY_AUTO_RESPONSE = 20,
120
121 // Shows the message in the console and chat history
122 IM_CONSOLE_AND_CHAT_HISTORY = 21,
123
124 // IM Types used for luring your friends
125 IM_LURE_USER = 22,
126 IM_LURE_ACCEPTED = 23,
127 IM_LURE_DECLINED = 24,
128 IM_GODLIKE_LURE_USER = 25,
129 IM_YET_TO_BE_USED = 26,
130
131 // IM that notifie of a new group election.
132 // Name is name of person who called vote.
133 // ID is election ID used for internal tracking
134 IM_GROUP_ELECTION_DEPRECATED = 27,
135
136 // IM to tell the user to go to an URL. Put a text message in the
137 // message field, and put the url with a trailing \0 in the binary
138 // bucket.
139 IM_GOTO_URL = 28,
140
141 // IM for help from the GAURDIAN_ANGELS
142 // Binary bucket contains the name of the session.
143 IM_SESSION_911_START = 29,
144
145 // IM sent automatically on call for help,
146 // sends a lure to each Helper reached
147 IM_LURE_911 = 30,
148
149 // a message generated by a script which we don't want to
150 // be sent through e-mail. Similar to IM_FROM_TASK, but
151 // it is shown as an alert on the viewer.
152 IM_FROM_TASK_AS_ALERT = 31,
153
154 // IM from group officer to all group members.
155 IM_GROUP_NOTICE = 32,
156 IM_GROUP_NOTICE_INVENTORY_ACCEPTED = 33,
157 IM_GROUP_NOTICE_INVENTORY_DECLINED = 34,
158
159 IM_GROUP_INVITATION_ACCEPT = 35,
160 IM_GROUP_INVITATION_DECLINE = 36,
161
162 IM_GROUP_NOTICE_REQUESTED = 37,
163
164 IM_FRIENDSHIP_OFFERED = 38,
165 IM_FRIENDSHIP_ACCEPTED = 39,
166 IM_FRIENDSHIP_DECLINED = 40,
167
168 IM_TYPING_START = 41,
169 IM_TYPING_STOP = 42,
170
171 IM_COUNT
172};
173
174
175// Hooks for quickly hacking in experimental admin debug messages
176// without needing to recompile the viewer
177// *NOTE: This functionality has been moved to be a string based
178// operation so that we don't even have to do a full recompile. This
179// enumeration will be phased out soon.
180enum EGodlikeRequest
181{
182 GOD_WANTS_NOTHING,
183
184 // for requesting physics information about an object
185 GOD_WANTS_HAVOK_INFO,
186
187 // two unused requests that can be appropriated for debug
188 // purposes (no viewer recompile necessary)
189 GOD_WANTS_FOO,
190 GOD_WANTS_BAR,
191
192 // to dump simulator terrain data to terrain.raw file
193 GOD_WANTS_TERRAIN_SAVE,
194 // to load simulator terrain data from terrain.raw file
195 GOD_WANTS_TERRAIN_LOAD,
196
197 GOD_WANTS_TOGGLE_AVATAR_GEOMETRY, // HACK for testing new avatar geom
198
199 // real-time telehub operations
200 GOD_WANTS_TELEHUB_INFO,
201 GOD_WANTS_CONNECT_TELEHUB,
202 GOD_WANTS_DELETE_TELEHUB,
203 GOD_WANTS_ADD_TELEHUB_SPAWNPOINT,
204 GOD_WANTS_REMOVE_TELEHUB_SPAWNPOINT,
205
206};
207
208enum EIMSource
209{
210 IM_FROM_VIEWER,
211 IM_FROM_DATASERVER,
212 IM_FROM_SIM
213};
214
215extern const U8 IM_ONLINE;
216extern const U8 IM_OFFLINE;
217
218extern const S32 VOTE_YES;
219extern const S32 VOTE_NO;
220extern const S32 VOTE_ABSTAIN;
221
222extern const S32 VOTE_MAJORITY;
223extern const S32 VOTE_SUPER_MAJORITY;
224extern const S32 VOTE_UNANIMOUS;
225
226extern const char EMPTY_BINARY_BUCKET[];
227extern const S32 EMPTY_BINARY_BUCKET_SIZE;
228
229extern const U32 NO_TIMESTAMP;
230extern const char SYSTEM_FROM[];
231
232// Number of retry attempts on sending the im.
233extern const S32 IM_TTL;
234
235
236class LLIMInfo : public LLRefCount
237{
238protected:
239 LLIMInfo();
240 ~LLIMInfo();
241
242public:
243 LLIMInfo(LLMessageSystem* msg,
244 EIMSource source = IM_FROM_SIM,
245 S32 ttl = IM_TTL);
246
247 LLIMInfo(
248 const LLUUID& from_id,
249 BOOL from_group,
250 const LLUUID& to_id,
251 EInstantMessage im_type,
252 const std::string& name,
253 const std::string& message,
254 const LLUUID& id,
255 U32 parent_estate_id,
256 const LLUUID& region_id,
257 const LLVector3& position,
258 LLSD data,
259 U8 offline,
260 U32 timestamp,
261 EIMSource source,
262 S32 ttl = IM_TTL);
263
264 void packInstantMessage(LLMessageSystem* msg) const;
265 void packMessageBlock(LLMessageSystem* msg) const;
266 void unpackMessageBlock(LLMessageSystem* msg);
267 LLPointer<LLIMInfo> clone();
268public:
269 LLUUID mFromID;
270 BOOL mFromGroup;
271 LLUUID mToID;
272 U32 mParentEstateID;
273 LLUUID mRegionID;
274 LLVector3 mPosition;
275 U8 mOffline;
276 bool mViewerThinksToIsOnline;
277 EInstantMessage mIMType;
278 LLUUID mID;
279 U32 mTimeStamp;
280 std::string mName;
281 std::string mMessage;
282 LLSD mData;
283
284 EIMSource mSource;
285 S32 mTTL;
286};
287
288
289void pack_instant_message(
290 LLMessageSystem* msgsystem,
291 const LLUUID& from_id,
292 BOOL from_group,
293 const LLUUID& session_id,
294 const LLUUID& to_id,
295 const char* name,
296 const char* message,
297 U8 offline = IM_ONLINE,
298 EInstantMessage dialog = IM_NOTHING_SPECIAL,
299 const LLUUID& id = LLUUID::null,
300 U32 parent_estate_id = 0,
301 const LLUUID& region_id = LLUUID::null,
302 const LLVector3& position = LLVector3::zero,
303 U32 timestamp = NO_TIMESTAMP,
304 const U8* binary_bucket = (U8*)EMPTY_BINARY_BUCKET,
305 S32 binary_bucket_size = EMPTY_BINARY_BUCKET_SIZE);
306
307void pack_instant_message_block(
308 LLMessageSystem* msgsystem,
309 const LLUUID& from_id,
310 BOOL from_group,
311 const LLUUID& session_id,
312 const LLUUID& to_id,
313 const char* name,
314 const char* message,
315 U8 offline = IM_ONLINE,
316 EInstantMessage dialog = IM_NOTHING_SPECIAL,
317 const LLUUID& id = LLUUID::null,
318 U32 parent_estate_id = 0,
319 const LLUUID& region_id = LLUUID::null,
320 const LLVector3& position = LLVector3::zero,
321 U32 timestamp = NO_TIMESTAMP,
322 const U8* binary_bucket = (U8*)EMPTY_BINARY_BUCKET,
323 S32 binary_bucket_size = EMPTY_BINARY_BUCKET_SIZE);
324
325
326#endif // LL_LLINSTANTMESSAGE_H
327