@fluidframework/presence 2.92.0 → 2.93.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4 -4
- package/dist/alpha.d.ts +6 -4
- package/dist/beta.d.ts +5 -2
- package/dist/getPresence.d.ts +4 -9
- package/dist/getPresence.d.ts.map +1 -1
- package/dist/getPresence.js +6 -86
- package/dist/getPresence.js.map +1 -1
- package/dist/index.d.ts +4 -13
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +8 -8
- package/dist/index.js.map +1 -1
- package/dist/legacy.alpha.d.ts +6 -4
- package/dist/package.json +1 -15
- package/dist/public.d.ts +69 -0
- package/lib/alpha.d.ts +6 -4
- package/lib/beta.d.ts +5 -2
- package/lib/getPresence.d.ts +4 -9
- package/lib/getPresence.d.ts.map +1 -1
- package/lib/getPresence.js +6 -85
- package/lib/getPresence.js.map +1 -1
- package/lib/index.d.ts +4 -13
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +5 -4
- package/lib/index.js.map +1 -1
- package/lib/legacy.alpha.d.ts +6 -4
- package/lib/public.d.ts +69 -0
- package/package.json +27 -76
- package/dist/baseTypes.d.ts +0 -24
- package/dist/baseTypes.d.ts.map +0 -1
- package/dist/baseTypes.js +0 -7
- package/dist/baseTypes.js.map +0 -1
- package/dist/broadcastControls.d.ts +0 -37
- package/dist/broadcastControls.d.ts.map +0 -1
- package/dist/broadcastControls.js +0 -60
- package/dist/broadcastControls.js.map +0 -1
- package/dist/broadcastControlsTypes.d.ts +0 -38
- package/dist/broadcastControlsTypes.d.ts.map +0 -1
- package/dist/broadcastControlsTypes.js +0 -7
- package/dist/broadcastControlsTypes.js.map +0 -1
- package/dist/exposedInternalTypes.d.ts +0 -138
- package/dist/exposedInternalTypes.d.ts.map +0 -1
- package/dist/exposedInternalTypes.js +0 -19
- package/dist/exposedInternalTypes.js.map +0 -1
- package/dist/exposedUtilityTypes.d.ts +0 -108
- package/dist/exposedUtilityTypes.d.ts.map +0 -1
- package/dist/exposedUtilityTypes.js +0 -7
- package/dist/exposedUtilityTypes.js.map +0 -1
- package/dist/internalUtils.d.ts +0 -125
- package/dist/internalUtils.d.ts.map +0 -1
- package/dist/internalUtils.js +0 -99
- package/dist/internalUtils.js.map +0 -1
- package/dist/latestMapTypes.d.ts +0 -343
- package/dist/latestMapTypes.d.ts.map +0 -1
- package/dist/latestMapTypes.js +0 -7
- package/dist/latestMapTypes.js.map +0 -1
- package/dist/latestMapValueManager.d.ts +0 -52
- package/dist/latestMapValueManager.d.ts.map +0 -1
- package/dist/latestMapValueManager.js +0 -250
- package/dist/latestMapValueManager.js.map +0 -1
- package/dist/latestTypes.d.ts +0 -183
- package/dist/latestTypes.d.ts.map +0 -1
- package/dist/latestTypes.js +0 -7
- package/dist/latestTypes.js.map +0 -1
- package/dist/latestValueManager.d.ts +0 -10
- package/dist/latestValueManager.d.ts.map +0 -1
- package/dist/latestValueManager.js +0 -117
- package/dist/latestValueManager.js.map +0 -1
- package/dist/latestValueTypes.d.ts +0 -108
- package/dist/latestValueTypes.d.ts.map +0 -1
- package/dist/latestValueTypes.js +0 -7
- package/dist/latestValueTypes.js.map +0 -1
- package/dist/notificationsManager.d.ts +0 -27
- package/dist/notificationsManager.d.ts.map +0 -1
- package/dist/notificationsManager.js +0 -98
- package/dist/notificationsManager.js.map +0 -1
- package/dist/notificationsManagerTypes.d.ts +0 -144
- package/dist/notificationsManagerTypes.d.ts.map +0 -1
- package/dist/notificationsManagerTypes.js +0 -7
- package/dist/notificationsManagerTypes.js.map +0 -1
- package/dist/packageVersion.d.ts +0 -9
- package/dist/packageVersion.d.ts.map +0 -1
- package/dist/packageVersion.js +0 -12
- package/dist/packageVersion.js.map +0 -1
- package/dist/presence.d.ts +0 -229
- package/dist/presence.d.ts.map +0 -1
- package/dist/presence.js +0 -23
- package/dist/presence.js.map +0 -1
- package/dist/presenceDatastoreManager.d.ts +0 -149
- package/dist/presenceDatastoreManager.d.ts.map +0 -1
- package/dist/presenceDatastoreManager.js +0 -667
- package/dist/presenceDatastoreManager.js.map +0 -1
- package/dist/presenceManager.d.ts +0 -16
- package/dist/presenceManager.d.ts.map +0 -1
- package/dist/presenceManager.js +0 -140
- package/dist/presenceManager.js.map +0 -1
- package/dist/presenceStates.d.ts +0 -102
- package/dist/presenceStates.d.ts.map +0 -1
- package/dist/presenceStates.js +0 -231
- package/dist/presenceStates.js.map +0 -1
- package/dist/protocol.d.ts +0 -111
- package/dist/protocol.d.ts.map +0 -1
- package/dist/protocol.js +0 -20
- package/dist/protocol.js.map +0 -1
- package/dist/runtimeTypes.d.ts +0 -26
- package/dist/runtimeTypes.d.ts.map +0 -1
- package/dist/runtimeTypes.js +0 -7
- package/dist/runtimeTypes.js.map +0 -1
- package/dist/stateDatastore.d.ts +0 -56
- package/dist/stateDatastore.d.ts.map +0 -1
- package/dist/stateDatastore.js +0 -22
- package/dist/stateDatastore.js.map +0 -1
- package/dist/stateFactory.d.ts +0 -18
- package/dist/stateFactory.d.ts.map +0 -1
- package/dist/stateFactory.js +0 -23
- package/dist/stateFactory.js.map +0 -1
- package/dist/statesManagerTypes.d.ts +0 -27
- package/dist/statesManagerTypes.d.ts.map +0 -1
- package/dist/statesManagerTypes.js +0 -7
- package/dist/statesManagerTypes.js.map +0 -1
- package/dist/systemWorkspace.d.ts +0 -58
- package/dist/systemWorkspace.d.ts.map +0 -1
- package/dist/systemWorkspace.js +0 -265
- package/dist/systemWorkspace.js.map +0 -1
- package/dist/timerManager.d.ts +0 -37
- package/dist/timerManager.d.ts.map +0 -1
- package/dist/timerManager.js +0 -65
- package/dist/timerManager.js.map +0 -1
- package/dist/types.d.ts +0 -132
- package/dist/types.d.ts.map +0 -1
- package/dist/types.js +0 -7
- package/dist/types.js.map +0 -1
- package/dist/validatableTypes.d.ts +0 -69
- package/dist/validatableTypes.d.ts.map +0 -1
- package/dist/validatableTypes.js +0 -7
- package/dist/validatableTypes.js.map +0 -1
- package/dist/validatedGetter.d.ts +0 -18
- package/dist/validatedGetter.d.ts.map +0 -1
- package/dist/validatedGetter.js +0 -43
- package/dist/validatedGetter.js.map +0 -1
- package/dist/valueManager.d.ts +0 -15
- package/dist/valueManager.d.ts.map +0 -1
- package/dist/valueManager.js +0 -22
- package/dist/valueManager.js.map +0 -1
- package/lib/baseTypes.d.ts +0 -24
- package/lib/baseTypes.d.ts.map +0 -1
- package/lib/baseTypes.js +0 -6
- package/lib/baseTypes.js.map +0 -1
- package/lib/broadcastControls.d.ts +0 -37
- package/lib/broadcastControls.d.ts.map +0 -1
- package/lib/broadcastControls.js +0 -55
- package/lib/broadcastControls.js.map +0 -1
- package/lib/broadcastControlsTypes.d.ts +0 -38
- package/lib/broadcastControlsTypes.d.ts.map +0 -1
- package/lib/broadcastControlsTypes.js +0 -6
- package/lib/broadcastControlsTypes.js.map +0 -1
- package/lib/exposedInternalTypes.d.ts +0 -138
- package/lib/exposedInternalTypes.d.ts.map +0 -1
- package/lib/exposedInternalTypes.js +0 -16
- package/lib/exposedInternalTypes.js.map +0 -1
- package/lib/exposedUtilityTypes.d.ts +0 -108
- package/lib/exposedUtilityTypes.d.ts.map +0 -1
- package/lib/exposedUtilityTypes.js +0 -6
- package/lib/exposedUtilityTypes.js.map +0 -1
- package/lib/internalUtils.d.ts +0 -125
- package/lib/internalUtils.d.ts.map +0 -1
- package/lib/internalUtils.js +0 -90
- package/lib/internalUtils.js.map +0 -1
- package/lib/latestMapTypes.d.ts +0 -343
- package/lib/latestMapTypes.d.ts.map +0 -1
- package/lib/latestMapTypes.js +0 -6
- package/lib/latestMapTypes.js.map +0 -1
- package/lib/latestMapValueManager.d.ts +0 -52
- package/lib/latestMapValueManager.d.ts.map +0 -1
- package/lib/latestMapValueManager.js +0 -246
- package/lib/latestMapValueManager.js.map +0 -1
- package/lib/latestTypes.d.ts +0 -183
- package/lib/latestTypes.d.ts.map +0 -1
- package/lib/latestTypes.js +0 -6
- package/lib/latestTypes.js.map +0 -1
- package/lib/latestValueManager.d.ts +0 -10
- package/lib/latestValueManager.d.ts.map +0 -1
- package/lib/latestValueManager.js +0 -113
- package/lib/latestValueManager.js.map +0 -1
- package/lib/latestValueTypes.d.ts +0 -108
- package/lib/latestValueTypes.d.ts.map +0 -1
- package/lib/latestValueTypes.js +0 -6
- package/lib/latestValueTypes.js.map +0 -1
- package/lib/notificationsManager.d.ts +0 -27
- package/lib/notificationsManager.d.ts.map +0 -1
- package/lib/notificationsManager.js +0 -94
- package/lib/notificationsManager.js.map +0 -1
- package/lib/notificationsManagerTypes.d.ts +0 -144
- package/lib/notificationsManagerTypes.d.ts.map +0 -1
- package/lib/notificationsManagerTypes.js +0 -6
- package/lib/notificationsManagerTypes.js.map +0 -1
- package/lib/packageVersion.d.ts +0 -9
- package/lib/packageVersion.d.ts.map +0 -1
- package/lib/packageVersion.js +0 -9
- package/lib/packageVersion.js.map +0 -1
- package/lib/presence.d.ts +0 -229
- package/lib/presence.d.ts.map +0 -1
- package/lib/presence.js +0 -20
- package/lib/presence.js.map +0 -1
- package/lib/presenceDatastoreManager.d.ts +0 -149
- package/lib/presenceDatastoreManager.d.ts.map +0 -1
- package/lib/presenceDatastoreManager.js +0 -663
- package/lib/presenceDatastoreManager.js.map +0 -1
- package/lib/presenceManager.d.ts +0 -16
- package/lib/presenceManager.d.ts.map +0 -1
- package/lib/presenceManager.js +0 -136
- package/lib/presenceManager.js.map +0 -1
- package/lib/presenceStates.d.ts +0 -102
- package/lib/presenceStates.d.ts.map +0 -1
- package/lib/presenceStates.js +0 -225
- package/lib/presenceStates.js.map +0 -1
- package/lib/protocol.d.ts +0 -111
- package/lib/protocol.d.ts.map +0 -1
- package/lib/protocol.js +0 -17
- package/lib/protocol.js.map +0 -1
- package/lib/runtimeTypes.d.ts +0 -26
- package/lib/runtimeTypes.d.ts.map +0 -1
- package/lib/runtimeTypes.js +0 -6
- package/lib/runtimeTypes.js.map +0 -1
- package/lib/stateDatastore.d.ts +0 -56
- package/lib/stateDatastore.d.ts.map +0 -1
- package/lib/stateDatastore.js +0 -17
- package/lib/stateDatastore.js.map +0 -1
- package/lib/stateFactory.d.ts +0 -18
- package/lib/stateFactory.d.ts.map +0 -1
- package/lib/stateFactory.js +0 -20
- package/lib/stateFactory.js.map +0 -1
- package/lib/statesManagerTypes.d.ts +0 -27
- package/lib/statesManagerTypes.d.ts.map +0 -1
- package/lib/statesManagerTypes.js +0 -6
- package/lib/statesManagerTypes.js.map +0 -1
- package/lib/systemWorkspace.d.ts +0 -58
- package/lib/systemWorkspace.d.ts.map +0 -1
- package/lib/systemWorkspace.js +0 -261
- package/lib/systemWorkspace.js.map +0 -1
- package/lib/timerManager.d.ts +0 -37
- package/lib/timerManager.d.ts.map +0 -1
- package/lib/timerManager.js +0 -61
- package/lib/timerManager.js.map +0 -1
- package/lib/types.d.ts +0 -132
- package/lib/types.d.ts.map +0 -1
- package/lib/types.js +0 -6
- package/lib/types.js.map +0 -1
- package/lib/validatableTypes.d.ts +0 -69
- package/lib/validatableTypes.d.ts.map +0 -1
- package/lib/validatableTypes.js +0 -6
- package/lib/validatableTypes.js.map +0 -1
- package/lib/validatedGetter.d.ts +0 -18
- package/lib/validatedGetter.d.ts.map +0 -1
- package/lib/validatedGetter.js +0 -39
- package/lib/validatedGetter.js.map +0 -1
- package/lib/valueManager.d.ts +0 -15
- package/lib/valueManager.d.ts.map +0 -1
- package/lib/valueManager.js +0 -17
- package/lib/valueManager.js.map +0 -1
package/dist/presence.d.ts
DELETED
|
@@ -1,229 +0,0 @@
|
|
|
1
|
-
/*!
|
|
2
|
-
* Copyright (c) Microsoft Corporation and contributors. All rights reserved.
|
|
3
|
-
* Licensed under the MIT License.
|
|
4
|
-
*/
|
|
5
|
-
import type { Listenable } from "@fluidframework/core-interfaces";
|
|
6
|
-
import type { SessionId } from "@fluidframework/id-compressor";
|
|
7
|
-
import type { ClientConnectionId } from "./baseTypes.js";
|
|
8
|
-
import type { BroadcastControlSettings } from "./broadcastControlsTypes.js";
|
|
9
|
-
import type { NotificationsWorkspace, NotificationsWorkspaceSchema, StatesWorkspace, StatesWorkspaceSchema, WorkspaceAddress } from "./types.js";
|
|
10
|
-
/**
|
|
11
|
-
* A Fluid client session identifier.
|
|
12
|
-
*
|
|
13
|
-
* @remarks
|
|
14
|
-
* Each client once connected to a session is given a unique identifier for the
|
|
15
|
-
* duration of the session. If a client disconnects and reconnects, it will
|
|
16
|
-
* retain its identifier. Prefer use of {@link Attendee} as a way to
|
|
17
|
-
* identify clients in a session. {@link Attendee.attendeeId} will provide
|
|
18
|
-
* the session ID.
|
|
19
|
-
*
|
|
20
|
-
* @beta
|
|
21
|
-
*/
|
|
22
|
-
export type AttendeeId = SessionId & {
|
|
23
|
-
readonly AttendeeId: "AttendeeId";
|
|
24
|
-
};
|
|
25
|
-
/**
|
|
26
|
-
* The connection status of the {@link Attendee}.
|
|
27
|
-
*
|
|
28
|
-
* @beta
|
|
29
|
-
*/
|
|
30
|
-
export declare const AttendeeStatus: {
|
|
31
|
-
/**
|
|
32
|
-
* The {@link Attendee} is connected to the Fluid service.
|
|
33
|
-
*/
|
|
34
|
-
readonly Connected: "Connected";
|
|
35
|
-
/**
|
|
36
|
-
* The {@link Attendee} is not connected to the Fluid service.
|
|
37
|
-
*/
|
|
38
|
-
readonly Disconnected: "Disconnected";
|
|
39
|
-
};
|
|
40
|
-
/**
|
|
41
|
-
* Represents the connection status of an {@link Attendee}.
|
|
42
|
-
*
|
|
43
|
-
* This type can be either `'Connected'` or `'Disconnected'`, indicating whether
|
|
44
|
-
* the attendee is currently connected to the Fluid service.
|
|
45
|
-
*
|
|
46
|
-
* When `'Disconnected'`:
|
|
47
|
-
* - State changes are kept locally and communicated to others upon reconnect.
|
|
48
|
-
* - Notification requests are discarded (silently).
|
|
49
|
-
*
|
|
50
|
-
* @beta
|
|
51
|
-
*/
|
|
52
|
-
export type AttendeeStatus = (typeof AttendeeStatus)[keyof typeof AttendeeStatus];
|
|
53
|
-
/**
|
|
54
|
-
* A client within a Fluid session (period of container connectivity to service).
|
|
55
|
-
*
|
|
56
|
-
* @remarks
|
|
57
|
-
* Note: This is very preliminary attendee representation.
|
|
58
|
-
*
|
|
59
|
-
* {@link Attendee} should be used as key to distinguish between different
|
|
60
|
-
* clients as they join, rejoin, and disconnect from a session. While a
|
|
61
|
-
* client's {@link ClientConnectionId} from {@link Attendee.getConnectionStatus}
|
|
62
|
-
* may change over time, `Attendee` will be fixed.
|
|
63
|
-
*
|
|
64
|
-
* @privateRemarks
|
|
65
|
-
* As this is evolved, pay attention to how this relates to Audience, Service
|
|
66
|
-
* Audience, and Quorum representations of clients and users.
|
|
67
|
-
*
|
|
68
|
-
* @sealed
|
|
69
|
-
* @beta
|
|
70
|
-
*/
|
|
71
|
-
export interface Attendee<SpecificAttendeeId extends AttendeeId = AttendeeId> {
|
|
72
|
-
/**
|
|
73
|
-
* The session ID of the client that is stable over all connections.
|
|
74
|
-
*/
|
|
75
|
-
readonly attendeeId: SpecificAttendeeId;
|
|
76
|
-
/**
|
|
77
|
-
* Get current client connection ID.
|
|
78
|
-
*
|
|
79
|
-
* @returns Current client connection ID.
|
|
80
|
-
*
|
|
81
|
-
* @remarks
|
|
82
|
-
* Connection ID will change on reconnect.
|
|
83
|
-
*
|
|
84
|
-
* If {@link Attendee.getConnectionStatus} is {@link (AttendeeStatus:variable).Disconnected}, this will represent the last known connection ID.
|
|
85
|
-
*/
|
|
86
|
-
getConnectionId(): ClientConnectionId;
|
|
87
|
-
/**
|
|
88
|
-
* Get connection status of attendee.
|
|
89
|
-
*
|
|
90
|
-
* @returns Connection status of attendee.
|
|
91
|
-
*
|
|
92
|
-
*/
|
|
93
|
-
getConnectionStatus(): AttendeeStatus;
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* Utility type limiting to a specific attendee. (A attendee with
|
|
97
|
-
* a specific session ID - not just any session ID.)
|
|
98
|
-
*/
|
|
99
|
-
export type SpecificAttendee<SpecificAttendeeId extends AttendeeId> = string extends SpecificAttendeeId ? never : Attendee<SpecificAttendeeId>;
|
|
100
|
-
/**
|
|
101
|
-
* Events from {@link Presence.attendees}.
|
|
102
|
-
*
|
|
103
|
-
* @sealed
|
|
104
|
-
* @beta
|
|
105
|
-
*/
|
|
106
|
-
export interface AttendeesEvents {
|
|
107
|
-
/**
|
|
108
|
-
* Raised when new client joins session.
|
|
109
|
-
*
|
|
110
|
-
* @eventProperty
|
|
111
|
-
*/
|
|
112
|
-
attendeeConnected: (attendee: Attendee) => void;
|
|
113
|
-
/**
|
|
114
|
-
* Raised when client appears disconnected from session.
|
|
115
|
-
*
|
|
116
|
-
* @eventProperty
|
|
117
|
-
*/
|
|
118
|
-
attendeeDisconnected: (attendee: Attendee) => void;
|
|
119
|
-
}
|
|
120
|
-
/**
|
|
121
|
-
* Events from {@link Presence}.
|
|
122
|
-
*
|
|
123
|
-
* @sealed
|
|
124
|
-
* @beta
|
|
125
|
-
*/
|
|
126
|
-
export interface PresenceEvents {
|
|
127
|
-
/**
|
|
128
|
-
* Raised when a workspace is activated within the session.
|
|
129
|
-
*
|
|
130
|
-
* "Activated" means that a workspace is being used by a client and this
|
|
131
|
-
* client is seeing information for the first time.
|
|
132
|
-
*
|
|
133
|
-
* @remarks
|
|
134
|
-
* Local workspaces may be passively acquired/registered when this event
|
|
135
|
-
* is raised. For a notifications workspace, that lazy registration must
|
|
136
|
-
* be done before the event handler returns to ensure no notifications
|
|
137
|
-
* are missed.
|
|
138
|
-
*/
|
|
139
|
-
workspaceActivated: (workspaceAddress: WorkspaceAddress, type: "States" | "Notifications" | "Unknown") => void;
|
|
140
|
-
}
|
|
141
|
-
/**
|
|
142
|
-
* Provides top-level access to Presence feature set including known
|
|
143
|
-
* {@link Attendee}s within a session and their custom states kept
|
|
144
|
-
* under {@link StatesWorkspace}s.
|
|
145
|
-
*
|
|
146
|
-
* @sealed
|
|
147
|
-
* @beta
|
|
148
|
-
*/
|
|
149
|
-
export interface Presence {
|
|
150
|
-
/**
|
|
151
|
-
* Events for Presence.
|
|
152
|
-
*/
|
|
153
|
-
readonly events: Listenable<PresenceEvents>;
|
|
154
|
-
/**
|
|
155
|
-
* Container-wide {@link Attendee} information and event provider.
|
|
156
|
-
*
|
|
157
|
-
* @remarks
|
|
158
|
-
* This provides access to all {@link Attendee}s in the session, including
|
|
159
|
-
* the current client. As {@link StatesWorkspace} aren't required to be
|
|
160
|
-
* uniform across an application, some {@link Attendee}s may be enumerated
|
|
161
|
-
* here while not being present in any particular {@link StatesWorkspace}.
|
|
162
|
-
*/
|
|
163
|
-
readonly attendees: {
|
|
164
|
-
/**
|
|
165
|
-
* Events for {@link Attendee}s.
|
|
166
|
-
*/
|
|
167
|
-
readonly events: Listenable<AttendeesEvents>;
|
|
168
|
-
/**
|
|
169
|
-
* Get all {@link Attendee}s in the session.
|
|
170
|
-
*
|
|
171
|
-
* @remarks
|
|
172
|
-
* Attendee states are dynamic and will change as clients join and leave
|
|
173
|
-
* the session.
|
|
174
|
-
*/
|
|
175
|
-
getAttendees(): ReadonlySet<Attendee>;
|
|
176
|
-
/**
|
|
177
|
-
* Lookup a specific {@link Attendee} in the session.
|
|
178
|
-
*
|
|
179
|
-
* @param clientId - Client connection or session ID
|
|
180
|
-
*/
|
|
181
|
-
getAttendee(clientId: ClientConnectionId | AttendeeId): Attendee;
|
|
182
|
-
/**
|
|
183
|
-
* Get this client's {@link Attendee}.
|
|
184
|
-
*
|
|
185
|
-
* @returns This client's attendee.
|
|
186
|
-
*/
|
|
187
|
-
getMyself(): Attendee;
|
|
188
|
-
};
|
|
189
|
-
/**
|
|
190
|
-
* Provides access to {@link StatesWorkspace}s that allow clients to
|
|
191
|
-
* manage custom states.
|
|
192
|
-
*/
|
|
193
|
-
readonly states: {
|
|
194
|
-
/**
|
|
195
|
-
* Acquires a {@link StatesWorkspace} from store or adds new one.
|
|
196
|
-
*
|
|
197
|
-
* @param workspaceAddress - Address of the requested {@link StatesWorkspace}
|
|
198
|
-
* @param requestedStates - Requested states for the workspace
|
|
199
|
-
* @param controls - Optional settings for default broadcast controls
|
|
200
|
-
* @returns A {@link StatesWorkspace}
|
|
201
|
-
*/
|
|
202
|
-
getWorkspace<StatesSchema extends Partial<StatesWorkspaceSchema<SchemaKeys>>, SchemaKeys extends string & keyof StatesSchema = string & keyof StatesSchema>(workspaceAddress: WorkspaceAddress, requestedStates: StatesSchema, controls?: BroadcastControlSettings): StatesWorkspace<StatesSchema, unknown, SchemaKeys>;
|
|
203
|
-
};
|
|
204
|
-
}
|
|
205
|
-
/**
|
|
206
|
-
* Provides top-level access to Presence feature set including known
|
|
207
|
-
* {@link Attendee}s within a session and their custom states and
|
|
208
|
-
* notifications kept under {@link StatesWorkspace}s and
|
|
209
|
-
* {@link NotificationsWorkspace}s.
|
|
210
|
-
*
|
|
211
|
-
* @remarks
|
|
212
|
-
* To access this alpha API, cast any `{@link Presence}` to `PresenceWithNotifications`.
|
|
213
|
-
*
|
|
214
|
-
* @sealed
|
|
215
|
-
* @alpha
|
|
216
|
-
*/
|
|
217
|
-
export interface PresenceWithNotifications extends Presence {
|
|
218
|
-
readonly notifications: {
|
|
219
|
-
/**
|
|
220
|
-
* Acquires a Notifications workspace from store or adds new one.
|
|
221
|
-
*
|
|
222
|
-
* @param workspaceAddress - Address of the requested Notifications Workspace
|
|
223
|
-
* @param requestedNotifications - Requested notifications for the workspace
|
|
224
|
-
* @returns A Notifications workspace
|
|
225
|
-
*/
|
|
226
|
-
getWorkspace<NotificationsSchema extends Partial<NotificationsWorkspaceSchema<SchemaKeys>>, SchemaKeys extends string & keyof NotificationsSchema = string & keyof NotificationsSchema>(notificationsId: WorkspaceAddress, requestedNotifications: NotificationsSchema): NotificationsWorkspace<NotificationsSchema, SchemaKeys>;
|
|
227
|
-
};
|
|
228
|
-
}
|
|
229
|
-
//# sourceMappingURL=presence.d.ts.map
|
package/dist/presence.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"presence.d.ts","sourceRoot":"","sources":["../src/presence.ts"],"names":[],"mappings":"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"}
|
package/dist/presence.js
DELETED
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/*!
|
|
3
|
-
* Copyright (c) Microsoft Corporation and contributors. All rights reserved.
|
|
4
|
-
* Licensed under the MIT License.
|
|
5
|
-
*/
|
|
6
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
-
exports.AttendeeStatus = void 0;
|
|
8
|
-
/**
|
|
9
|
-
* The connection status of the {@link Attendee}.
|
|
10
|
-
*
|
|
11
|
-
* @beta
|
|
12
|
-
*/
|
|
13
|
-
exports.AttendeeStatus = {
|
|
14
|
-
/**
|
|
15
|
-
* The {@link Attendee} is connected to the Fluid service.
|
|
16
|
-
*/
|
|
17
|
-
Connected: "Connected",
|
|
18
|
-
/**
|
|
19
|
-
* The {@link Attendee} is not connected to the Fluid service.
|
|
20
|
-
*/
|
|
21
|
-
Disconnected: "Disconnected",
|
|
22
|
-
};
|
|
23
|
-
//# sourceMappingURL=presence.js.map
|
package/dist/presence.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"presence.js","sourceRoot":"","sources":["../src/presence.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AA6BH;;;;GAIG;AACU,QAAA,cAAc,GAAG;IAC7B;;OAEG;IACH,SAAS,EAAE,WAAW;IAEtB;;OAEG;IACH,YAAY,EAAE,cAAc;CACnB,CAAC","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\n\nimport type { Listenable } from \"@fluidframework/core-interfaces\";\nimport type { SessionId } from \"@fluidframework/id-compressor\";\n\nimport type { ClientConnectionId } from \"./baseTypes.js\";\nimport type { BroadcastControlSettings } from \"./broadcastControlsTypes.js\";\nimport type {\n\tNotificationsWorkspace,\n\tNotificationsWorkspaceSchema,\n\tStatesWorkspace,\n\tStatesWorkspaceSchema,\n\tWorkspaceAddress,\n} from \"./types.js\";\n\n/**\n * A Fluid client session identifier.\n *\n * @remarks\n * Each client once connected to a session is given a unique identifier for the\n * duration of the session. If a client disconnects and reconnects, it will\n * retain its identifier. Prefer use of {@link Attendee} as a way to\n * identify clients in a session. {@link Attendee.attendeeId} will provide\n * the session ID.\n *\n * @beta\n */\nexport type AttendeeId = SessionId & { readonly AttendeeId: \"AttendeeId\" };\n\n/**\n * The connection status of the {@link Attendee}.\n *\n * @beta\n */\nexport const AttendeeStatus = {\n\t/**\n\t * The {@link Attendee} is connected to the Fluid service.\n\t */\n\tConnected: \"Connected\",\n\n\t/**\n\t * The {@link Attendee} is not connected to the Fluid service.\n\t */\n\tDisconnected: \"Disconnected\",\n} as const;\n\n/**\n * Represents the connection status of an {@link Attendee}.\n *\n * This type can be either `'Connected'` or `'Disconnected'`, indicating whether\n * the attendee is currently connected to the Fluid service.\n *\n * When `'Disconnected'`:\n * - State changes are kept locally and communicated to others upon reconnect.\n * - Notification requests are discarded (silently).\n *\n * @beta\n */\nexport type AttendeeStatus = (typeof AttendeeStatus)[keyof typeof AttendeeStatus];\n\n/**\n * A client within a Fluid session (period of container connectivity to service).\n *\n * @remarks\n * Note: This is very preliminary attendee representation.\n *\n * {@link Attendee} should be used as key to distinguish between different\n * clients as they join, rejoin, and disconnect from a session. While a\n * client's {@link ClientConnectionId} from {@link Attendee.getConnectionStatus}\n * may change over time, `Attendee` will be fixed.\n *\n * @privateRemarks\n * As this is evolved, pay attention to how this relates to Audience, Service\n * Audience, and Quorum representations of clients and users.\n *\n * @sealed\n * @beta\n */\nexport interface Attendee<SpecificAttendeeId extends AttendeeId = AttendeeId> {\n\t/**\n\t * The session ID of the client that is stable over all connections.\n\t */\n\treadonly attendeeId: SpecificAttendeeId;\n\n\t/**\n\t * Get current client connection ID.\n\t *\n\t * @returns Current client connection ID.\n\t *\n\t * @remarks\n\t * Connection ID will change on reconnect.\n\t *\n\t * If {@link Attendee.getConnectionStatus} is {@link (AttendeeStatus:variable).Disconnected}, this will represent the last known connection ID.\n\t */\n\tgetConnectionId(): ClientConnectionId;\n\n\t/**\n\t * Get connection status of attendee.\n\t *\n\t * @returns Connection status of attendee.\n\t *\n\t */\n\tgetConnectionStatus(): AttendeeStatus;\n}\n\n/**\n * Utility type limiting to a specific attendee. (A attendee with\n * a specific session ID - not just any session ID.)\n */\nexport type SpecificAttendee<SpecificAttendeeId extends AttendeeId> =\n\tstring extends SpecificAttendeeId ? never : Attendee<SpecificAttendeeId>;\n\n/**\n * Events from {@link Presence.attendees}.\n *\n * @sealed\n * @beta\n */\nexport interface AttendeesEvents {\n\t/**\n\t * Raised when new client joins session.\n\t *\n\t * @eventProperty\n\t */\n\tattendeeConnected: (attendee: Attendee) => void;\n\n\t/**\n\t * Raised when client appears disconnected from session.\n\t *\n\t * @eventProperty\n\t */\n\tattendeeDisconnected: (attendee: Attendee) => void;\n}\n\n/**\n * Events from {@link Presence}.\n *\n * @sealed\n * @beta\n */\nexport interface PresenceEvents {\n\t/**\n\t * Raised when a workspace is activated within the session.\n\t *\n\t * \"Activated\" means that a workspace is being used by a client and this\n\t * client is seeing information for the first time.\n\t *\n\t * @remarks\n\t * Local workspaces may be passively acquired/registered when this event\n\t * is raised. For a notifications workspace, that lazy registration must\n\t * be done before the event handler returns to ensure no notifications\n\t * are missed.\n\t */\n\tworkspaceActivated: (\n\t\tworkspaceAddress: WorkspaceAddress,\n\t\ttype: \"States\" | \"Notifications\" | \"Unknown\",\n\t) => void;\n}\n\n/**\n * Provides top-level access to Presence feature set including known\n * {@link Attendee}s within a session and their custom states kept\n * under {@link StatesWorkspace}s.\n *\n * @sealed\n * @beta\n */\nexport interface Presence {\n\t/**\n\t * Events for Presence.\n\t */\n\treadonly events: Listenable<PresenceEvents>;\n\n\t/**\n\t * Container-wide {@link Attendee} information and event provider.\n\t *\n\t * @remarks\n\t * This provides access to all {@link Attendee}s in the session, including\n\t * the current client. As {@link StatesWorkspace} aren't required to be\n\t * uniform across an application, some {@link Attendee}s may be enumerated\n\t * here while not being present in any particular {@link StatesWorkspace}.\n\t */\n\treadonly attendees: {\n\t\t/**\n\t\t * Events for {@link Attendee}s.\n\t\t */\n\t\treadonly events: Listenable<AttendeesEvents>;\n\n\t\t/**\n\t\t * Get all {@link Attendee}s in the session.\n\t\t *\n\t\t * @remarks\n\t\t * Attendee states are dynamic and will change as clients join and leave\n\t\t * the session.\n\t\t */\n\t\tgetAttendees(): ReadonlySet<Attendee>;\n\n\t\t/**\n\t\t * Lookup a specific {@link Attendee} in the session.\n\t\t *\n\t\t * @param clientId - Client connection or session ID\n\t\t */\n\t\tgetAttendee(clientId: ClientConnectionId | AttendeeId): Attendee;\n\n\t\t/**\n\t\t * Get this client's {@link Attendee}.\n\t\t *\n\t\t * @returns This client's attendee.\n\t\t */\n\t\tgetMyself(): Attendee;\n\t};\n\n\t/**\n\t * Provides access to {@link StatesWorkspace}s that allow clients to\n\t * manage custom states.\n\t */\n\treadonly states: {\n\t\t/**\n\t\t * Acquires a {@link StatesWorkspace} from store or adds new one.\n\t\t *\n\t\t * @param workspaceAddress - Address of the requested {@link StatesWorkspace}\n\t\t * @param requestedStates - Requested states for the workspace\n\t\t * @param controls - Optional settings for default broadcast controls\n\t\t * @returns A {@link StatesWorkspace}\n\t\t */\n\t\tgetWorkspace<\n\t\t\tStatesSchema extends Partial<StatesWorkspaceSchema<SchemaKeys>>,\n\t\t\tSchemaKeys extends string & keyof StatesSchema = string & keyof StatesSchema,\n\t\t>(\n\t\t\tworkspaceAddress: WorkspaceAddress,\n\t\t\trequestedStates: StatesSchema,\n\t\t\tcontrols?: BroadcastControlSettings,\n\t\t): StatesWorkspace<StatesSchema, unknown, SchemaKeys>;\n\t};\n}\n\n/**\n * Provides top-level access to Presence feature set including known\n * {@link Attendee}s within a session and their custom states and\n * notifications kept under {@link StatesWorkspace}s and\n * {@link NotificationsWorkspace}s.\n *\n * @remarks\n * To access this alpha API, cast any `{@link Presence}` to `PresenceWithNotifications`.\n *\n * @sealed\n * @alpha\n */\nexport interface PresenceWithNotifications extends Presence {\n\treadonly notifications: {\n\t\t/**\n\t\t * Acquires a Notifications workspace from store or adds new one.\n\t\t *\n\t\t * @param workspaceAddress - Address of the requested Notifications Workspace\n\t\t * @param requestedNotifications - Requested notifications for the workspace\n\t\t * @returns A Notifications workspace\n\t\t */\n\t\tgetWorkspace<\n\t\t\tNotificationsSchema extends Partial<NotificationsWorkspaceSchema<SchemaKeys>>,\n\t\t\tSchemaKeys extends string & keyof NotificationsSchema = string &\n\t\t\t\tkeyof NotificationsSchema,\n\t\t>(\n\t\t\tnotificationsId: WorkspaceAddress,\n\t\t\trequestedNotifications: NotificationsSchema,\n\t\t): NotificationsWorkspace<NotificationsSchema, SchemaKeys>;\n\t};\n}\n"]}
|
|
@@ -1,149 +0,0 @@
|
|
|
1
|
-
/*!
|
|
2
|
-
* Copyright (c) Microsoft Corporation and contributors. All rights reserved.
|
|
3
|
-
* Licensed under the MIT License.
|
|
4
|
-
*/
|
|
5
|
-
import type { InboundExtensionMessage } from "@fluidframework/container-runtime-definitions/internal";
|
|
6
|
-
import type { IEmitter } from "@fluidframework/core-interfaces/internal";
|
|
7
|
-
import type { ITelemetryLoggerExt } from "@fluidframework/telemetry-utils/internal";
|
|
8
|
-
import type { ClientConnectionId } from "./baseTypes.js";
|
|
9
|
-
import type { BroadcastControlSettings } from "./broadcastControlsTypes.js";
|
|
10
|
-
import type { AttendeeId, PresenceWithNotifications as Presence, PresenceEvents } from "./presence.js";
|
|
11
|
-
import type { PresenceStatesInternal } from "./presenceStates.js";
|
|
12
|
-
import type { InternalWorkspaceAddress, SignalMessages } from "./protocol.js";
|
|
13
|
-
import type { IEphemeralRuntime } from "./runtimeTypes.js";
|
|
14
|
-
import type { SystemWorkspaceDatastore } from "./systemWorkspace.js";
|
|
15
|
-
import type { AnyWorkspace, NotificationsWorkspace, NotificationsWorkspaceSchema, StatesWorkspace, StatesWorkspaceSchema, WorkspaceAddress } from "./types.js";
|
|
16
|
-
interface AnyWorkspaceEntry<TSchema extends StatesWorkspaceSchema> {
|
|
17
|
-
public: AnyWorkspace<TSchema>;
|
|
18
|
-
internal: PresenceStatesInternal;
|
|
19
|
-
}
|
|
20
|
-
/**
|
|
21
|
-
* High-level contract for manager of singleton Presence datastore
|
|
22
|
-
*/
|
|
23
|
-
export interface PresenceDatastoreManager {
|
|
24
|
-
joinSession(clientId: ClientConnectionId, alternateProvider: ClientConnectionId | undefined): void;
|
|
25
|
-
onDisconnected(): void;
|
|
26
|
-
getWorkspace<TSchema extends Partial<StatesWorkspaceSchema<TSchemaKeys>>, TSchemaKeys extends string & keyof TSchema>(internalWorkspaceAddress: `s:${WorkspaceAddress}`, requestedContent: TSchema, controls?: BroadcastControlSettings): StatesWorkspace<TSchema, unknown, TSchemaKeys>;
|
|
27
|
-
getWorkspace<TSchema extends Partial<NotificationsWorkspaceSchema<TSchemaKeys>>, TSchemaKeys extends string & keyof TSchema>(internalWorkspaceAddress: `n:${WorkspaceAddress}`, requestedContent: TSchema): NotificationsWorkspace<TSchema, TSchemaKeys>;
|
|
28
|
-
processSignal(message: InboundExtensionMessage<SignalMessages> & {
|
|
29
|
-
clientId: ClientConnectionId;
|
|
30
|
-
}, local: boolean, optional: boolean): void;
|
|
31
|
-
}
|
|
32
|
-
/**
|
|
33
|
-
* Delays used for broadcasting join responses to clients.
|
|
34
|
-
*
|
|
35
|
-
* @remarks
|
|
36
|
-
* Exported for test coordination.
|
|
37
|
-
* These could be made customizable in the future to accommodate different
|
|
38
|
-
* session configurations.
|
|
39
|
-
*/
|
|
40
|
-
export declare const broadcastJoinResponseDelaysMs: {
|
|
41
|
-
/**
|
|
42
|
-
* The delay in milliseconds before a join response is sent to any client.
|
|
43
|
-
* This is used to accumulate other join response requests and reduce
|
|
44
|
-
* network traffic.
|
|
45
|
-
*/
|
|
46
|
-
readonly namedResponder: 200;
|
|
47
|
-
/**
|
|
48
|
-
* The additional delay in milliseconds a backup responder waits before sending
|
|
49
|
-
* a join response to allow others to respond first.
|
|
50
|
-
*/
|
|
51
|
-
readonly backupResponderIncrement: 40;
|
|
52
|
-
};
|
|
53
|
-
/**
|
|
54
|
-
* Manages singleton datastore for all Presence.
|
|
55
|
-
*/
|
|
56
|
-
export declare class PresenceDatastoreManagerImpl implements PresenceDatastoreManager {
|
|
57
|
-
private readonly attendeeId;
|
|
58
|
-
private readonly runtime;
|
|
59
|
-
private readonly logger;
|
|
60
|
-
private readonly events;
|
|
61
|
-
private readonly presence;
|
|
62
|
-
private readonly datastore;
|
|
63
|
-
private averageLatency;
|
|
64
|
-
private returnedMessages;
|
|
65
|
-
private readonly sendMessageTimer;
|
|
66
|
-
private readonly workspaces;
|
|
67
|
-
private readonly targetedSignalSupport;
|
|
68
|
-
/**
|
|
69
|
-
* Tracks whether this client has complete snapshot level knowledge and
|
|
70
|
-
* how that determination was reached.
|
|
71
|
-
* - "alone": no other audience members detected at join
|
|
72
|
-
* - "join response": another client has responded to our join request
|
|
73
|
-
* - "full requests": all others have requested response from us
|
|
74
|
-
*
|
|
75
|
-
* @remarks
|
|
76
|
-
* Only applies when not using targeted join responses.
|
|
77
|
-
*
|
|
78
|
-
* Without a complete snapshot, we cannot fully onboard any other clients.
|
|
79
|
-
* One exception to this is if this client is the only participant in the
|
|
80
|
-
* session. In such a case, there is no one to respond to the join request.
|
|
81
|
-
* Another exception is multiple clients attempting to join at the same
|
|
82
|
-
* time and thus expecting that someone has full knowledge, yet none have
|
|
83
|
-
* received a complete update to think they are qualified to respond.
|
|
84
|
-
* Generically if the number of outstanding requestors meets or exceeds the
|
|
85
|
-
* count of other audience members, then we can consider the snapshot
|
|
86
|
-
* complete (as all will have provided their own complete information in
|
|
87
|
-
* their join responses).
|
|
88
|
-
*/
|
|
89
|
-
private reasonForCompleteSnapshot?;
|
|
90
|
-
/**
|
|
91
|
-
* Map of outstanding broadcast (join response) requests.
|
|
92
|
-
*/
|
|
93
|
-
private readonly broadcastRequests;
|
|
94
|
-
/**
|
|
95
|
-
* Timer for managing broadcast (join response) request timing.
|
|
96
|
-
*/
|
|
97
|
-
private readonly broadcastRequestsTimer;
|
|
98
|
-
constructor(attendeeId: AttendeeId, runtime: IEphemeralRuntime, logger: ITelemetryLoggerExt, events: IEmitter<PresenceEvents>, presence: Presence, systemWorkspaceDatastore: SystemWorkspaceDatastore, systemWorkspace: AnyWorkspaceEntry<StatesWorkspaceSchema>);
|
|
99
|
-
private getAudienceInformation;
|
|
100
|
-
joinSession(selfClientId: ClientConnectionId, alternateProvider?: ClientConnectionId | undefined): void;
|
|
101
|
-
onDisconnected(): void;
|
|
102
|
-
getWorkspace<TSchema extends StatesWorkspaceSchema>(internalWorkspaceAddress: InternalWorkspaceAddress, requestedContent: TSchema, controls?: BroadcastControlSettings): AnyWorkspace<TSchema>;
|
|
103
|
-
/**
|
|
104
|
-
* The combined contents of all queued updates. Will be `"sendAll"` when a
|
|
105
|
-
* full broadcast is pending or `undefined` when no messages are queued.
|
|
106
|
-
*/
|
|
107
|
-
private queuedData;
|
|
108
|
-
/**
|
|
109
|
-
* Enqueues a new message to be sent. The message may be queued or may be sent immediately depending on the state of
|
|
110
|
-
* the send timer, other messages in the queue, the configured allowed latency, etc.
|
|
111
|
-
*/
|
|
112
|
-
private enqueueMessage;
|
|
113
|
-
/**
|
|
114
|
-
* Send any queued signal immediately. Does nothing if no message is queued.
|
|
115
|
-
*/
|
|
116
|
-
private sendQueuedMessage;
|
|
117
|
-
/**
|
|
118
|
-
* Recursively strips validation metadata (validatedValue) from datastore before broadcasting.
|
|
119
|
-
* This ensures that validation metadata doesn't leak into signals sent to other clients.
|
|
120
|
-
*/
|
|
121
|
-
private stripValidationMetadata;
|
|
122
|
-
/**
|
|
123
|
-
* Strips validation metadata from individual value data entries.
|
|
124
|
-
*/
|
|
125
|
-
private stripValidationFromValueData;
|
|
126
|
-
private broadcastAllKnownState;
|
|
127
|
-
processSignal(message: InboundExtensionMessage<SignalMessages> & {
|
|
128
|
-
clientId: ClientConnectionId;
|
|
129
|
-
}, local: boolean, optional: boolean): void;
|
|
130
|
-
/**
|
|
131
|
-
* Broadcasts a join response (complete datastore update message)
|
|
132
|
-
* if there is an outstanding join response request.
|
|
133
|
-
*/
|
|
134
|
-
private readonly sendJoinResponseIfStillNeeded;
|
|
135
|
-
/**
|
|
136
|
-
* Handles responding to another client joining the session.
|
|
137
|
-
*
|
|
138
|
-
* @param updateProviders - list of client connection id's that requestor selected
|
|
139
|
-
* to provide response
|
|
140
|
-
* @param requestor - `requestor` is only used in telemetry. While it is the requestor's
|
|
141
|
-
* client connection id, that is not most important. It is important that this is a
|
|
142
|
-
* unique shared id across all clients that might respond as we want to monitor the
|
|
143
|
-
* response patterns. The convenience of being client connection id will allow
|
|
144
|
-
* correlation with other telemetry where it is often called just `clientId`.
|
|
145
|
-
*/
|
|
146
|
-
private prepareJoinResponse;
|
|
147
|
-
}
|
|
148
|
-
export {};
|
|
149
|
-
//# sourceMappingURL=presenceDatastoreManager.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"presenceDatastoreManager.d.ts","sourceRoot":"","sources":["../src/presenceDatastoreManager.ts"],"names":[],"mappings":"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"}
|