@unwanted/matrix-sdk-mini 34.13.0 → 36.0.1
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/git-revision.txt +1 -1
- package/lib/@types/event.d.ts +25 -0
- package/lib/@types/event.d.ts.map +1 -1
- package/lib/@types/event.js +5 -0
- package/lib/@types/event.js.map +1 -1
- package/lib/client.d.ts +44 -19
- package/lib/client.d.ts.map +1 -1
- package/lib/client.js +148 -90
- package/lib/client.js.map +1 -1
- package/lib/embedded.d.ts +4 -3
- package/lib/embedded.d.ts.map +1 -1
- package/lib/embedded.js +57 -74
- package/lib/embedded.js.map +1 -1
- package/lib/feature.d.ts.map +1 -1
- package/lib/feature.js +2 -1
- package/lib/feature.js.map +1 -1
- package/lib/http-api/errors.d.ts +3 -3
- package/lib/http-api/errors.js +3 -3
- package/lib/http-api/errors.js.map +1 -1
- package/lib/http-api/utils.js +2 -2
- package/lib/http-api/utils.js.map +1 -1
- package/lib/models/event-timeline.d.ts.map +1 -1
- package/lib/models/event-timeline.js +1 -21
- package/lib/models/event-timeline.js.map +1 -1
- package/lib/models/event.d.ts +11 -1
- package/lib/models/event.d.ts.map +1 -1
- package/lib/models/event.js +48 -5
- package/lib/models/event.js.map +1 -1
- package/lib/models/invites-ignorer-types.d.ts +27 -0
- package/lib/models/invites-ignorer-types.d.ts.map +1 -0
- package/lib/models/invites-ignorer-types.js +36 -0
- package/lib/models/invites-ignorer-types.js.map +1 -0
- package/lib/models/invites-ignorer.d.ts +2 -26
- package/lib/models/invites-ignorer.d.ts.map +1 -1
- package/lib/models/invites-ignorer.js +2 -27
- package/lib/models/invites-ignorer.js.map +1 -1
- package/lib/models/room-member.d.ts +6 -1
- package/lib/models/room-member.d.ts.map +1 -1
- package/lib/models/room-member.js +7 -1
- package/lib/models/room-member.js.map +1 -1
- package/lib/models/room.d.ts +6 -1
- package/lib/models/room.d.ts.map +1 -1
- package/lib/models/room.js +7 -1
- package/lib/models/room.js.map +1 -1
- package/lib/oidc/authorize.d.ts +2 -2
- package/lib/oidc/authorize.d.ts.map +1 -1
- package/lib/oidc/authorize.js +5 -5
- package/lib/oidc/authorize.js.map +1 -1
- package/lib/oidc/discovery.d.ts +8 -0
- package/lib/oidc/discovery.d.ts.map +1 -1
- package/lib/oidc/discovery.js +22 -11
- package/lib/oidc/discovery.js.map +1 -1
- package/lib/oidc/index.d.ts +3 -4
- package/lib/oidc/index.d.ts.map +1 -1
- package/lib/oidc/index.js.map +1 -1
- package/lib/oidc/register.js +3 -3
- package/lib/oidc/register.js.map +1 -1
- package/lib/oidc/tokenRefresher.d.ts.map +1 -1
- package/lib/oidc/tokenRefresher.js +6 -5
- package/lib/oidc/tokenRefresher.js.map +1 -1
- package/lib/oidc/validate.d.ts +9 -23
- package/lib/oidc/validate.d.ts.map +1 -1
- package/lib/oidc/validate.js +13 -28
- package/lib/oidc/validate.js.map +1 -1
- package/lib/randomstring.d.ts +30 -3
- package/lib/randomstring.d.ts.map +1 -1
- package/lib/randomstring.js +68 -16
- package/lib/randomstring.js.map +1 -1
- package/lib/store/indexeddb-local-backend.js +4 -2
- package/lib/store/indexeddb-local-backend.js.map +1 -1
- package/lib/testing.d.ts +17 -0
- package/lib/testing.d.ts.map +1 -1
- package/lib/testing.js +42 -0
- package/lib/testing.js.map +1 -1
- package/package.json +5 -5
- package/src/@types/event.ts +17 -0
- package/src/client.ts +87 -41
- package/src/embedded.ts +41 -51
- package/src/feature.ts +1 -0
- package/src/http-api/errors.ts +3 -3
- package/src/http-api/utils.ts +2 -2
- package/src/models/event-timeline.ts +1 -21
- package/src/models/event.ts +46 -0
- package/src/models/invites-ignorer-types.ts +48 -0
- package/src/models/invites-ignorer.ts +7 -42
- package/src/models/room-member.ts +16 -1
- package/src/models/room.ts +16 -1
- package/src/oidc/authorize.ts +7 -7
- package/src/oidc/discovery.ts +16 -10
- package/src/oidc/index.ts +3 -4
- package/src/oidc/register.ts +3 -3
- package/src/oidc/tokenRefresher.ts +3 -2
- package/src/oidc/validate.ts +40 -63
- package/src/randomstring.ts +65 -19
- package/src/store/indexeddb-local-backend.ts +2 -2
- package/src/testing.ts +41 -0
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"errors.js","names":["HTTPError","Error","constructor","msg","httpStatus","httpHeaders","isRateLimitError","getRetryAfterMs","_this$httpHeaders","retryAfter","get","test","ms","Number","parseInt","isFinite","date","Date","toUTCString","getTime","now","MatrixError","errorJson","arguments","length","undefined","url","event","message","error","concat","_defineProperty","errcode","name","data","headerValue","isInteger","retry_after_ms","asWidgetApiErrorData","_this$httpStatus","_this$url","_this$errcode","_this$data$error","headers","value","http_status","http_headers","response","_objectSpread","fromWidgetApiErrorData","Headers","safeGetRetryAfterMs","defaultMs","_error$getRetryAfterM","_unused","ConnectionError","cause"],"sources":["../../src/http-api/errors.ts"],"sourcesContent":["/*\nCopyright 2022 - 2024 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { IMatrixApiError as IWidgetMatrixError } from \"matrix-widget-api\";\n\nimport { IUsageLimit } from \"../@types/partials.ts\";\nimport { MatrixEvent } from \"../models/event.ts\";\n\ninterface IErrorJson extends Partial<IUsageLimit> {\n [key: string]: any; // extensible\n errcode?: string;\n error?: string;\n}\n\n/**\n * Construct a generic HTTP error. This is a JavaScript Error with additional information\n * specific to HTTP responses.\n * @param msg - The error message to include.\n * @param httpStatus - The HTTP response status code.\n * @param httpHeaders - The HTTP response headers.\n */\nexport class HTTPError extends Error {\n public constructor(\n msg: string,\n public readonly httpStatus?: number,\n public readonly httpHeaders?: Headers,\n ) {\n super(msg);\n }\n\n /**\n * Check if this error was due to rate-limiting on the server side (and should therefore be retried after a delay).\n *\n * If this returns `true`, {@link getRetryAfterMs} can be called to retrieve the server-side\n * recommendation for the retry period.\n *\n * @returns Whether this error is due to rate-limiting.\n */\n public isRateLimitError(): boolean {\n return this.httpStatus === 429;\n }\n\n /**\n * @returns The recommended delay in milliseconds to wait before retrying\n * the request that triggered this error, or null if no delay is recommended.\n * @throws Error if the recommended delay is an invalid value.\n * @see {@link safeGetRetryAfterMs} for a version of this check that doesn't throw.\n */\n public getRetryAfterMs(): number | null {\n const retryAfter = this.httpHeaders?.get(\"Retry-After\");\n if (retryAfter != null) {\n if (/^\\d+$/.test(retryAfter)) {\n const ms = Number.parseInt(retryAfter) * 1000;\n if (!Number.isFinite(ms)) {\n throw new Error(\"Retry-After header integer value is too large\");\n }\n return ms;\n }\n const date = new Date(retryAfter);\n if (date.toUTCString() !== retryAfter) {\n throw new Error(\"Retry-After header value is not a valid HTTP-date or non-negative decimal integer\");\n }\n return date.getTime() - Date.now();\n }\n return null;\n }\n}\n\nexport class MatrixError extends HTTPError {\n // The Matrix 'errcode' value, e.g. \"M_FORBIDDEN\".\n public readonly errcode?: string;\n // The raw Matrix error JSON used to construct this object.\n public data: IErrorJson;\n\n /**\n * Construct a Matrix error. This is a JavaScript Error with additional\n * information specific to the standard Matrix error response.\n * @param errorJson - The Matrix error JSON returned from the homeserver.\n * @param httpStatus - The numeric HTTP status code given\n * @param httpHeaders - The HTTP response headers given\n */\n public constructor(\n errorJson: IErrorJson = {},\n httpStatus?: number,\n public url?: string,\n public event?: MatrixEvent,\n httpHeaders?: Headers,\n ) {\n let message = errorJson.error || \"Unknown message\";\n if (httpStatus) {\n message = `[${httpStatus}] ${message}`;\n }\n if (url) {\n message = `${message} (${url})`;\n }\n super(`MatrixError: ${message}`, httpStatus, httpHeaders);\n this.errcode = errorJson.errcode;\n this.name = errorJson.errcode || \"Unknown error code\";\n this.data = errorJson;\n }\n\n public isRateLimitError(): boolean {\n return (\n this.errcode === \"M_LIMIT_EXCEEDED\" ||\n ((this.errcode === \"M_UNKNOWN\" || this.errcode === undefined) && super.isRateLimitError())\n );\n }\n\n public getRetryAfterMs(): number | null {\n const headerValue = super.getRetryAfterMs();\n if (headerValue !== null) {\n return headerValue;\n }\n // Note: retry_after_ms is deprecated as of spec version v1.10\n if (this.errcode === \"M_LIMIT_EXCEEDED\" && \"retry_after_ms\" in this.data) {\n if (!Number.isInteger(this.data.retry_after_ms)) {\n throw new Error(\"retry_after_ms is not an integer\");\n }\n return this.data.retry_after_ms;\n }\n return null;\n }\n\n /**\n * @returns this error expressed as a JSON payload\n * for use by Widget API error responses.\n */\n public asWidgetApiErrorData(): IWidgetMatrixError {\n const headers: Record<string, string> = {};\n if (this.httpHeaders) {\n for (const [name, value] of this.httpHeaders) {\n headers[name] = value;\n }\n }\n return {\n http_status: this.httpStatus ?? 400,\n http_headers: headers,\n url: this.url ?? \"\",\n response: {\n errcode: this.errcode ?? \"M_UNKNOWN\",\n error: this.data.error ?? \"Unknown message\",\n ...this.data,\n },\n };\n }\n\n /**\n * @returns a new {@link MatrixError} from a JSON payload\n * received from Widget API error responses.\n */\n public static fromWidgetApiErrorData(data: IWidgetMatrixError): MatrixError {\n return new MatrixError(data.response, data.http_status, data.url, undefined, new Headers(data.http_headers));\n }\n}\n\n/**\n * @returns The recommended delay in milliseconds to wait before retrying\n * the request that triggered {@link error}, or {@link defaultMs} if the\n * error was not due to rate-limiting or if no valid delay is recommended.\n */\nexport function safeGetRetryAfterMs(error: unknown, defaultMs: number): number {\n if (!(error instanceof HTTPError) || !error.isRateLimitError()) {\n return defaultMs;\n }\n try {\n return error.getRetryAfterMs() ?? defaultMs;\n } catch {\n return defaultMs;\n }\n}\n\n/**\n * Construct a ConnectionError. This is a JavaScript Error indicating\n * that a request failed because of some error with the connection, either\n * CORS was not correctly configured on the server, the server didn't response,\n * the request timed out, or the internet connection on the client side went down.\n */\nexport class ConnectionError extends Error {\n public constructor(message: string, cause?: Error) {\n super(message + (cause ? `: ${cause.message}` : \"\"));\n }\n\n public get name(): string {\n return \"ConnectionError\";\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
1
|
+
{"version":3,"file":"errors.js","names":["HTTPError","Error","constructor","msg","httpStatus","httpHeaders","isRateLimitError","getRetryAfterMs","_this$httpHeaders","retryAfter","get","test","ms","Number","parseInt","isFinite","date","Date","toUTCString","getTime","now","MatrixError","errorJson","arguments","length","undefined","url","event","message","error","concat","_defineProperty","errcode","name","data","headerValue","isInteger","retry_after_ms","asWidgetApiErrorData","_this$httpStatus","_this$url","_this$errcode","_this$data$error","headers","value","http_status","http_headers","response","_objectSpread","fromWidgetApiErrorData","Headers","safeGetRetryAfterMs","defaultMs","_error$getRetryAfterM","_unused","ConnectionError","cause"],"sources":["../../src/http-api/errors.ts"],"sourcesContent":["/*\nCopyright 2022 - 2024 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { IMatrixApiError as IWidgetMatrixError } from \"matrix-widget-api\";\n\nimport { IUsageLimit } from \"../@types/partials.ts\";\nimport { MatrixEvent } from \"../models/event.ts\";\n\ninterface IErrorJson extends Partial<IUsageLimit> {\n [key: string]: any; // extensible\n errcode?: string;\n error?: string;\n}\n\n/**\n * Construct a generic HTTP error. This is a JavaScript Error with additional information\n * specific to HTTP responses.\n * @param msg - The error message to include.\n * @param httpStatus - The HTTP response status code.\n * @param httpHeaders - The HTTP response headers.\n */\nexport class HTTPError extends Error {\n public constructor(\n msg: string,\n public readonly httpStatus?: number,\n public readonly httpHeaders?: Headers,\n ) {\n super(msg);\n }\n\n /**\n * Check if this error was due to rate-limiting on the server side (and should therefore be retried after a delay).\n *\n * If this returns `true`, {@link getRetryAfterMs} can be called to retrieve the server-side\n * recommendation for the retry period.\n *\n * @returns Whether this error is due to rate-limiting.\n */\n public isRateLimitError(): boolean {\n return this.httpStatus === 429;\n }\n\n /**\n * @returns The recommended delay in milliseconds to wait before retrying\n * the request that triggered this error, or null if no delay is recommended.\n * @throws Error if the recommended delay is an invalid value.\n * @see {@link safeGetRetryAfterMs} for a version of this check that doesn't throw.\n */\n public getRetryAfterMs(): number | null {\n const retryAfter = this.httpHeaders?.get(\"Retry-After\");\n if (retryAfter != null) {\n if (/^\\d+$/.test(retryAfter)) {\n const ms = Number.parseInt(retryAfter) * 1000;\n if (!Number.isFinite(ms)) {\n throw new Error(\"Retry-After header integer value is too large\");\n }\n return ms;\n }\n const date = new Date(retryAfter);\n if (date.toUTCString() !== retryAfter) {\n throw new Error(\"Retry-After header value is not a valid HTTP-date or non-negative decimal integer\");\n }\n return date.getTime() - Date.now();\n }\n return null;\n }\n}\n\nexport class MatrixError extends HTTPError {\n // The Matrix 'errcode' value, e.g. \"M_FORBIDDEN\".\n public readonly errcode?: string;\n // The raw Matrix error JSON used to construct this object.\n public data: IErrorJson;\n\n /**\n * Construct a Matrix error. This is a JavaScript Error with additional\n * information specific to the standard Matrix error response.\n * @param errorJson - The Matrix error JSON returned from the homeserver.\n * @param httpStatus - The numeric HTTP status code given\n * @param httpHeaders - The HTTP response headers given\n */\n public constructor(\n errorJson: IErrorJson = {},\n httpStatus?: number,\n public url?: string,\n public event?: MatrixEvent,\n httpHeaders?: Headers,\n ) {\n let message = errorJson.error || \"Unknown message\";\n if (httpStatus) {\n message = `[${httpStatus}] ${message}`;\n }\n if (url) {\n message = `${message} (${url})`;\n }\n super(`MatrixError: ${message}`, httpStatus, httpHeaders);\n this.errcode = errorJson.errcode;\n this.name = errorJson.errcode || \"Unknown error code\";\n this.data = errorJson;\n }\n\n public isRateLimitError(): boolean {\n return (\n this.errcode === \"M_LIMIT_EXCEEDED\" ||\n ((this.errcode === \"M_UNKNOWN\" || this.errcode === undefined) && super.isRateLimitError())\n );\n }\n\n public getRetryAfterMs(): number | null {\n const headerValue = super.getRetryAfterMs();\n if (headerValue !== null) {\n return headerValue;\n }\n // Note: retry_after_ms is deprecated as of spec version v1.10\n if (this.errcode === \"M_LIMIT_EXCEEDED\" && \"retry_after_ms\" in this.data) {\n if (!Number.isInteger(this.data.retry_after_ms)) {\n throw new Error(\"retry_after_ms is not an integer\");\n }\n return this.data.retry_after_ms;\n }\n return null;\n }\n\n /**\n * @returns this error expressed as a JSON payload\n * for use by Widget API error responses.\n */\n public asWidgetApiErrorData(): IWidgetMatrixError {\n const headers: Record<string, string> = {};\n if (this.httpHeaders) {\n for (const [name, value] of this.httpHeaders) {\n headers[name] = value;\n }\n }\n return {\n http_status: this.httpStatus ?? 400,\n http_headers: headers,\n url: this.url ?? \"\",\n response: {\n errcode: this.errcode ?? \"M_UNKNOWN\",\n error: this.data.error ?? \"Unknown message\",\n ...this.data,\n },\n };\n }\n\n /**\n * @returns a new {@link MatrixError} from a JSON payload\n * received from Widget API error responses.\n */\n public static fromWidgetApiErrorData(data: IWidgetMatrixError): MatrixError {\n return new MatrixError(data.response, data.http_status, data.url, undefined, new Headers(data.http_headers));\n }\n}\n\n/**\n * @returns The recommended delay in milliseconds to wait before retrying the request.\n * @param error - The error to check for a retry delay.\n * @param defaultMs - The delay to use if the error was not due to rate-limiting or if no valid delay is recommended.\n */\nexport function safeGetRetryAfterMs(error: unknown, defaultMs: number): number {\n if (!(error instanceof HTTPError) || !error.isRateLimitError()) {\n return defaultMs;\n }\n try {\n return error.getRetryAfterMs() ?? defaultMs;\n } catch {\n return defaultMs;\n }\n}\n\n/**\n * Construct a ConnectionError. This is a JavaScript Error indicating\n * that a request failed because of some error with the connection, either\n * CORS was not correctly configured on the server, the server didn't response,\n * the request timed out, or the internet connection on the client side went down.\n */\nexport class ConnectionError extends Error {\n public constructor(message: string, cause?: Error) {\n super(message + (cause ? `: ${cause.message}` : \"\"));\n }\n\n public get name(): string {\n return \"ConnectionError\";\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
package/lib/http-api/utils.js
CHANGED
@@ -159,8 +159,8 @@ export function calculateRetryBackoff(err, attempts, retryConnectionError) {
|
|
159
159
|
if (err instanceof ConnectionError && !retryConnectionError) {
|
160
160
|
return -1;
|
161
161
|
}
|
162
|
-
if (err.httpStatus && (err.httpStatus
|
163
|
-
// client error; no amount of retrying will save you now
|
162
|
+
if (err.httpStatus && Math.floor(err.httpStatus / 100) === 4 && err.httpStatus !== 429) {
|
163
|
+
// client error; no amount of retrying will save you now (except for rate limiting which is handled below)
|
164
164
|
return -1;
|
165
165
|
}
|
166
166
|
if (err.name === "AbortError") {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"utils.js","names":["parse","parseContentType","logger","sleep","ConnectionError","HTTPError","MatrixError","safeGetRetryAfterMs","timeoutSignal","ms","controller","AbortController","setTimeout","abort","signal","anySignal","signals","cleanup","removeEventListener","onAbort","aborted","addEventListener","parseErrorResponse","response","body","_contentType","_contentType2","httpHeaders","isXhr","Headers","getAllResponseHeaders","trim","split","map","header","colonIdx","indexOf","substring","headers","contentType","getResponseContentType","e","type","JSON","status","responseURL","url","undefined","concat","get","Error","retryNetworkOperation","_x","_x2","_retryNetworkOperation","apply","arguments","_asyncToGenerator","maxAttempts","callback","attempts","lastConnectionError","timeout","Math","pow","log","err","calculateRetryBackoff","retryConnectionError","httpStatus","name"],"sources":["../../src/http-api/utils.ts"],"sourcesContent":["/*\nCopyright 2022 - 2024 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { parse as parseContentType, ParsedMediaType } from \"content-type\";\n\nimport { logger } from \"../logger.ts\";\nimport { sleep } from \"../utils.ts\";\nimport { ConnectionError, HTTPError, MatrixError, safeGetRetryAfterMs } from \"./errors.ts\";\n\n// Ponyfill for https://developer.mozilla.org/en-US/docs/Web/API/AbortSignal/timeout\nexport function timeoutSignal(ms: number): AbortSignal {\n const controller = new AbortController();\n setTimeout(() => {\n controller.abort();\n }, ms);\n\n return controller.signal;\n}\n\nexport function anySignal(signals: AbortSignal[]): {\n signal: AbortSignal;\n cleanup(): void;\n} {\n const controller = new AbortController();\n\n function cleanup(): void {\n for (const signal of signals) {\n signal.removeEventListener(\"abort\", onAbort);\n }\n }\n\n function onAbort(): void {\n controller.abort();\n cleanup();\n }\n\n for (const signal of signals) {\n if (signal.aborted) {\n onAbort();\n break;\n }\n signal.addEventListener(\"abort\", onAbort);\n }\n\n return {\n signal: controller.signal,\n cleanup,\n };\n}\n\n/**\n * Attempt to turn an HTTP error response into a Javascript Error.\n *\n * If it is a JSON response, we will parse it into a MatrixError. Otherwise\n * we return a generic Error.\n *\n * @param response - response object\n * @param body - raw body of the response\n * @returns\n */\nexport function parseErrorResponse(response: XMLHttpRequest | Response, body?: string): Error {\n const httpHeaders = isXhr(response)\n ? new Headers(\n response\n .getAllResponseHeaders()\n .trim()\n .split(/[\\r\\n]+/)\n .map((header): [string, string] => {\n const colonIdx = header.indexOf(\":\");\n return [header.substring(0, colonIdx), header.substring(colonIdx + 1)];\n }),\n )\n : response.headers;\n\n let contentType: ParsedMediaType | null;\n try {\n contentType = getResponseContentType(httpHeaders);\n } catch (e) {\n return <Error>e;\n }\n if (contentType?.type === \"application/json\" && body) {\n return new MatrixError(\n JSON.parse(body),\n response.status,\n isXhr(response) ? response.responseURL : response.url,\n undefined,\n httpHeaders,\n );\n }\n if (contentType?.type === \"text/plain\") {\n return new HTTPError(`Server returned ${response.status} error: ${body}`, response.status, httpHeaders);\n }\n return new HTTPError(`Server returned ${response.status} error`, response.status, httpHeaders);\n}\n\nfunction isXhr(response: XMLHttpRequest | Response): response is XMLHttpRequest {\n return \"getResponseHeader\" in response;\n}\n\n/**\n * extract the Content-Type header from response headers, and\n * parse it to a `{type, parameters}` object.\n *\n * returns null if no content-type header could be found.\n *\n * @param response - response object\n * @returns parsed content-type header, or null if not found\n */\nfunction getResponseContentType(headers: Headers): ParsedMediaType | null {\n const contentType = headers.get(\"Content-Type\");\n if (contentType === null) return null;\n\n try {\n return parseContentType(contentType);\n } catch (e) {\n throw new Error(`Error parsing Content-Type '${contentType}': ${e}`);\n }\n}\n\n/**\n * Retries a network operation run in a callback.\n * @param maxAttempts - maximum attempts to try\n * @param callback - callback that returns a promise of the network operation. If rejected with ConnectionError, it will be retried by calling the callback again.\n * @returns the result of the network operation\n * @throws {@link ConnectionError} If after maxAttempts the callback still throws ConnectionError\n */\nexport async function retryNetworkOperation<T>(maxAttempts: number, callback: () => Promise<T>): Promise<T> {\n let attempts = 0;\n let lastConnectionError: ConnectionError | null = null;\n while (attempts < maxAttempts) {\n try {\n if (attempts > 0) {\n const timeout = 1000 * Math.pow(2, attempts);\n logger.log(`network operation failed ${attempts} times, retrying in ${timeout}ms...`);\n await sleep(timeout);\n }\n return await callback();\n } catch (err) {\n if (err instanceof ConnectionError) {\n attempts += 1;\n lastConnectionError = err;\n } else {\n throw err;\n }\n }\n }\n throw lastConnectionError;\n}\n\n/**\n * Calculate the backoff time for a request retry attempt.\n * This produces wait times of 2, 4, 8, and 16 seconds (30s total) after which we give up. If the\n * failure was due to a rate limited request, the time specified in the error is returned.\n *\n * Returns -1 if the error is not retryable, or if we reach the maximum number of attempts.\n *\n * @param err - The error thrown by the http call\n * @param attempts - The number of attempts made so far, including the one that just failed.\n * @param retryConnectionError - Whether to retry on {@link ConnectionError} (CORS, connection is down, etc.)\n */\nexport function calculateRetryBackoff(err: any, attempts: number, retryConnectionError: boolean): number {\n if (attempts > 4) {\n return -1; // give up\n }\n\n if (err instanceof ConnectionError && !retryConnectionError) {\n return -1;\n }\n\n if (err.httpStatus && (err.httpStatus === 400 || err.httpStatus === 403 || err.httpStatus === 401)) {\n // client error; no amount of retrying will save you now.\n return -1;\n }\n\n if (err.name === \"AbortError\") {\n // this is a client timeout, that is already very high 60s/80s\n // we don't want to retry, as it could do it for very long\n return -1;\n }\n\n // If we are trying to send an event (or similar) that is too large in any way, then retrying won't help\n if (err.name === \"M_TOO_LARGE\") {\n return -1;\n }\n\n return safeGetRetryAfterMs(err, 1000 * Math.pow(2, attempts));\n}\n"],"mappings":"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","ignoreList":[]}
|
1
|
+
{"version":3,"file":"utils.js","names":["parse","parseContentType","logger","sleep","ConnectionError","HTTPError","MatrixError","safeGetRetryAfterMs","timeoutSignal","ms","controller","AbortController","setTimeout","abort","signal","anySignal","signals","cleanup","removeEventListener","onAbort","aborted","addEventListener","parseErrorResponse","response","body","_contentType","_contentType2","httpHeaders","isXhr","Headers","getAllResponseHeaders","trim","split","map","header","colonIdx","indexOf","substring","headers","contentType","getResponseContentType","e","type","JSON","status","responseURL","url","undefined","concat","get","Error","retryNetworkOperation","_x","_x2","_retryNetworkOperation","apply","arguments","_asyncToGenerator","maxAttempts","callback","attempts","lastConnectionError","timeout","Math","pow","log","err","calculateRetryBackoff","retryConnectionError","httpStatus","floor","name"],"sources":["../../src/http-api/utils.ts"],"sourcesContent":["/*\nCopyright 2022 - 2024 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { parse as parseContentType, ParsedMediaType } from \"content-type\";\n\nimport { logger } from \"../logger.ts\";\nimport { sleep } from \"../utils.ts\";\nimport { ConnectionError, HTTPError, MatrixError, safeGetRetryAfterMs } from \"./errors.ts\";\n\n// Ponyfill for https://developer.mozilla.org/en-US/docs/Web/API/AbortSignal/timeout\nexport function timeoutSignal(ms: number): AbortSignal {\n const controller = new AbortController();\n setTimeout(() => {\n controller.abort();\n }, ms);\n\n return controller.signal;\n}\n\nexport function anySignal(signals: AbortSignal[]): {\n signal: AbortSignal;\n cleanup(): void;\n} {\n const controller = new AbortController();\n\n function cleanup(): void {\n for (const signal of signals) {\n signal.removeEventListener(\"abort\", onAbort);\n }\n }\n\n function onAbort(): void {\n controller.abort();\n cleanup();\n }\n\n for (const signal of signals) {\n if (signal.aborted) {\n onAbort();\n break;\n }\n signal.addEventListener(\"abort\", onAbort);\n }\n\n return {\n signal: controller.signal,\n cleanup,\n };\n}\n\n/**\n * Attempt to turn an HTTP error response into a Javascript Error.\n *\n * If it is a JSON response, we will parse it into a MatrixError. Otherwise\n * we return a generic Error.\n *\n * @param response - response object\n * @param body - raw body of the response\n * @returns\n */\nexport function parseErrorResponse(response: XMLHttpRequest | Response, body?: string): Error {\n const httpHeaders = isXhr(response)\n ? new Headers(\n response\n .getAllResponseHeaders()\n .trim()\n .split(/[\\r\\n]+/)\n .map((header): [string, string] => {\n const colonIdx = header.indexOf(\":\");\n return [header.substring(0, colonIdx), header.substring(colonIdx + 1)];\n }),\n )\n : response.headers;\n\n let contentType: ParsedMediaType | null;\n try {\n contentType = getResponseContentType(httpHeaders);\n } catch (e) {\n return <Error>e;\n }\n if (contentType?.type === \"application/json\" && body) {\n return new MatrixError(\n JSON.parse(body),\n response.status,\n isXhr(response) ? response.responseURL : response.url,\n undefined,\n httpHeaders,\n );\n }\n if (contentType?.type === \"text/plain\") {\n return new HTTPError(`Server returned ${response.status} error: ${body}`, response.status, httpHeaders);\n }\n return new HTTPError(`Server returned ${response.status} error`, response.status, httpHeaders);\n}\n\nfunction isXhr(response: XMLHttpRequest | Response): response is XMLHttpRequest {\n return \"getResponseHeader\" in response;\n}\n\n/**\n * extract the Content-Type header from response headers, and\n * parse it to a `{type, parameters}` object.\n *\n * returns null if no content-type header could be found.\n *\n * @param response - response object\n * @returns parsed content-type header, or null if not found\n */\nfunction getResponseContentType(headers: Headers): ParsedMediaType | null {\n const contentType = headers.get(\"Content-Type\");\n if (contentType === null) return null;\n\n try {\n return parseContentType(contentType);\n } catch (e) {\n throw new Error(`Error parsing Content-Type '${contentType}': ${e}`);\n }\n}\n\n/**\n * Retries a network operation run in a callback.\n * @param maxAttempts - maximum attempts to try\n * @param callback - callback that returns a promise of the network operation. If rejected with ConnectionError, it will be retried by calling the callback again.\n * @returns the result of the network operation\n * @throws {@link ConnectionError} If after maxAttempts the callback still throws ConnectionError\n */\nexport async function retryNetworkOperation<T>(maxAttempts: number, callback: () => Promise<T>): Promise<T> {\n let attempts = 0;\n let lastConnectionError: ConnectionError | null = null;\n while (attempts < maxAttempts) {\n try {\n if (attempts > 0) {\n const timeout = 1000 * Math.pow(2, attempts);\n logger.log(`network operation failed ${attempts} times, retrying in ${timeout}ms...`);\n await sleep(timeout);\n }\n return await callback();\n } catch (err) {\n if (err instanceof ConnectionError) {\n attempts += 1;\n lastConnectionError = err;\n } else {\n throw err;\n }\n }\n }\n throw lastConnectionError;\n}\n\n/**\n * Calculate the backoff time for a request retry attempt.\n * This produces wait times of 2, 4, 8, and 16 seconds (30s total) after which we give up. If the\n * failure was due to a rate limited request, the time specified in the error is returned.\n *\n * Returns -1 if the error is not retryable, or if we reach the maximum number of attempts.\n *\n * @param err - The error thrown by the http call\n * @param attempts - The number of attempts made so far, including the one that just failed.\n * @param retryConnectionError - Whether to retry on {@link ConnectionError} (CORS, connection is down, etc.)\n */\nexport function calculateRetryBackoff(err: any, attempts: number, retryConnectionError: boolean): number {\n if (attempts > 4) {\n return -1; // give up\n }\n\n if (err instanceof ConnectionError && !retryConnectionError) {\n return -1;\n }\n\n if (err.httpStatus && Math.floor(err.httpStatus / 100) === 4 && err.httpStatus !== 429) {\n // client error; no amount of retrying will save you now (except for rate limiting which is handled below)\n return -1;\n }\n\n if (err.name === \"AbortError\") {\n // this is a client timeout, that is already very high 60s/80s\n // we don't want to retry, as it could do it for very long\n return -1;\n }\n\n // If we are trying to send an event (or similar) that is too large in any way, then retrying won't help\n if (err.name === \"M_TOO_LARGE\") {\n return -1;\n }\n\n return safeGetRetryAfterMs(err, 1000 * Math.pow(2, attempts));\n}\n"],"mappings":"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","ignoreList":[]}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"event-timeline.d.ts","sourceRoot":"","sources":["../../src/models/event-timeline.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,mBAAmB,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAGtC,MAAM,WAAW,uBAAwB,SAAQ,IAAI,CAAC,mBAAmB,EAAE,kBAAkB,CAAC;CAM7F;AAED,MAAM,WAAW,gBAAiB,SAAQ,IAAI,CAAC,mBAAmB,EAAE,kBAAkB,CAAC;IACnF;;iBAEa;IACb,iBAAiB,EAAE,OAAO,CAAC;IAC3B,kDAAkD;IAClD,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB;;;+EAG2E;IAC3E,UAAU,EAAE,OAAO,CAAC;CACvB;AAED,oBAAY,SAAS;IACjB,QAAQ,MAAM;IACd,OAAO,MAAM;CAChB;AAED,qBAAa,aAAa;
|
1
|
+
{"version":3,"file":"event-timeline.d.ts","sourceRoot":"","sources":["../../src/models/event-timeline.ts"],"names":[],"mappings":"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"}
|
@@ -31,27 +31,7 @@ export class EventTimeline {
|
|
31
31
|
* @param toStartOfTimeline - if true the event's forwardLooking flag is set false
|
32
32
|
*/
|
33
33
|
static setEventMetadata(event, stateContext, toStartOfTimeline) {
|
34
|
-
|
35
|
-
// When we try to generate a sentinel member before we have that member
|
36
|
-
// in the members object, we still generate a sentinel but it doesn't
|
37
|
-
// have a membership event, so test to see if events.member is set. We
|
38
|
-
// check this to avoid overriding non-sentinel members by sentinel ones
|
39
|
-
// when adding the event to a filtered timeline
|
40
|
-
if (!((_event$sender = event.sender) !== null && _event$sender !== void 0 && (_event$sender = _event$sender.events) !== null && _event$sender !== void 0 && _event$sender.member)) {
|
41
|
-
event.sender = stateContext.getSentinelMember(event.getSender());
|
42
|
-
}
|
43
|
-
if (!((_event$target = event.target) !== null && _event$target !== void 0 && (_event$target = _event$target.events) !== null && _event$target !== void 0 && _event$target.member) && event.getType() === EventType.RoomMember) {
|
44
|
-
event.target = stateContext.getSentinelMember(event.getStateKey());
|
45
|
-
}
|
46
|
-
if (event.isState()) {
|
47
|
-
// room state has no concept of 'old' or 'current', but we want the
|
48
|
-
// room state to regress back to previous values if toStartOfTimeline
|
49
|
-
// is set, which means inspecting prev_content if it exists. This
|
50
|
-
// is done by toggling the forwardLooking flag.
|
51
|
-
if (toStartOfTimeline) {
|
52
|
-
event.forwardLooking = false;
|
53
|
-
}
|
54
|
-
}
|
34
|
+
event.setMetadata(stateContext, toStartOfTimeline);
|
55
35
|
}
|
56
36
|
/**
|
57
37
|
* Construct a new EventTimeline
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"event-timeline.js","names":["RoomState","EventType","Direction","EventTimeline","setEventMetadata","event","stateContext","toStartOfTimeline","_event$sender","_event$target","sender","events","member","getSentinelMember","getSender","target","getType","RoomMember","getStateKey","isState","forwardLooking","constructor","eventTimelineSet","_eventTimelineSet$roo","_eventTimelineSet$roo2","_defineProperty","Backward","Forward","roomId","room","startState","endState","paginationRequests","b","f","name","Date","toISOString","initialiseState","stateEvents","_this$startState","_this$endState","timelineWasEmpty","arguments","length","undefined","Error","setStateEvents","forkLive","direction","forkState","getState","timeline","clone","fork","getRoomId","getFilter","getTimelineSet","getBaseIndex","baseIndex","getEvents","BACKWARDS","FORWARDS","getPaginationToken","paginationToken","startToken","endToken","setPaginationToken","token","getNeighbouringTimeline","prevTimeline","nextTimeline","setNeighbouringTimeline","neighbour","addEvent","_ref","roomState","addToState","timelineSet","getUnfilteredTimelineSet","_roomState","insertIndex","splice","insertEvent","removeEvent","eventId","i","ev","getId","toString"],"sources":["../../src/models/event-timeline.ts"],"sourcesContent":["/*\nCopyright 2016 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { IMarkerFoundOptions, RoomState } from \"./room-state.ts\";\nimport { EventTimelineSet } from \"./event-timeline-set.ts\";\nimport { MatrixEvent } from \"./event.ts\";\nimport { Filter } from \"../filter.ts\";\nimport { EventType } from \"../@types/event.ts\";\n\nexport interface IInitialiseStateOptions extends Pick<IMarkerFoundOptions, \"timelineWasEmpty\"> {\n // This is a separate interface without any extra stuff currently added on\n // top of `IMarkerFoundOptions` just because it feels like they have\n // different concerns. One shouldn't necessarily look to add to\n // `IMarkerFoundOptions` just because they want to add an extra option to\n // `initialiseState`.\n}\n\nexport interface IAddEventOptions extends Pick<IMarkerFoundOptions, \"timelineWasEmpty\"> {\n /** Whether to insert the new event at the start of the timeline where the\n * oldest events are (timeline is in chronological order, oldest to most\n * recent) */\n toStartOfTimeline: boolean;\n /** The state events to reconcile metadata from */\n roomState?: RoomState;\n /** Whether to add timeline events to the state as was done in legacy sync v2.\n * If true then timeline events will be added to the state.\n * In sync v2 with org.matrix.msc4222.use_state_after and simplified sliding sync,\n * all state arrives explicitly and timeline events should not be added. */\n addToState: boolean;\n}\n\nexport enum Direction {\n Backward = \"b\",\n Forward = \"f\",\n}\n\nexport class EventTimeline {\n /**\n * Symbolic constant for methods which take a 'direction' argument:\n * refers to the start of the timeline, or backwards in time.\n */\n public static readonly BACKWARDS = Direction.Backward;\n\n /**\n * Symbolic constant for methods which take a 'direction' argument:\n * refers to the end of the timeline, or forwards in time.\n */\n public static readonly FORWARDS = Direction.Forward;\n\n /**\n * Static helper method to set sender and target properties\n *\n * @param event - the event whose metadata is to be set\n * @param stateContext - the room state to be queried\n * @param toStartOfTimeline - if true the event's forwardLooking flag is set false\n */\n public static setEventMetadata(event: MatrixEvent, stateContext: RoomState, toStartOfTimeline: boolean): void {\n // When we try to generate a sentinel member before we have that member\n // in the members object, we still generate a sentinel but it doesn't\n // have a membership event, so test to see if events.member is set. We\n // check this to avoid overriding non-sentinel members by sentinel ones\n // when adding the event to a filtered timeline\n if (!event.sender?.events?.member) {\n event.sender = stateContext.getSentinelMember(event.getSender()!);\n }\n if (!event.target?.events?.member && event.getType() === EventType.RoomMember) {\n event.target = stateContext.getSentinelMember(event.getStateKey()!);\n }\n\n if (event.isState()) {\n // room state has no concept of 'old' or 'current', but we want the\n // room state to regress back to previous values if toStartOfTimeline\n // is set, which means inspecting prev_content if it exists. This\n // is done by toggling the forwardLooking flag.\n if (toStartOfTimeline) {\n event.forwardLooking = false;\n }\n }\n }\n\n private readonly roomId: string | null;\n private readonly name: string;\n private events: MatrixEvent[] = [];\n private baseIndex = 0;\n\n private startState?: RoomState;\n private endState?: RoomState;\n // If we have a roomId then we delegate pagination token storage to the room state objects `startState` and\n // `endState`, but for things like the notification timeline which mix multiple rooms we store the tokens ourselves.\n private startToken: string | null = null;\n private endToken: string | null = null;\n\n private prevTimeline: EventTimeline | null = null;\n private nextTimeline: EventTimeline | null = null;\n public paginationRequests: Record<Direction, Promise<boolean> | null> = {\n [Direction.Backward]: null,\n [Direction.Forward]: null,\n };\n\n /**\n * Construct a new EventTimeline\n *\n * <p>An EventTimeline represents a contiguous sequence of events in a room.\n *\n * <p>As well as keeping track of the events themselves, it stores the state of\n * the room at the beginning and end of the timeline, and pagination tokens for\n * going backwards and forwards in the timeline.\n *\n * <p>In order that clients can meaningfully maintain an index into a timeline,\n * the EventTimeline object tracks a 'baseIndex'. This starts at zero, but is\n * incremented when events are prepended to the timeline. The index of an event\n * relative to baseIndex therefore remains constant.\n *\n * <p>Once a timeline joins up with its neighbour, they are linked together into a\n * doubly-linked list.\n *\n * @param eventTimelineSet - the set of timelines this is part of\n */\n public constructor(private readonly eventTimelineSet: EventTimelineSet) {\n this.roomId = eventTimelineSet.room?.roomId ?? null;\n if (this.roomId) {\n this.startState = new RoomState(this.roomId);\n this.endState = new RoomState(this.roomId);\n }\n\n // this is used by client.js\n this.paginationRequests = { b: null, f: null };\n\n this.name = this.roomId + \":\" + new Date().toISOString();\n }\n\n /**\n * Initialise the start and end state with the given events\n *\n * <p>This can only be called before any events are added.\n *\n * @param stateEvents - list of state events to initialise the\n * state with.\n * @throws Error if an attempt is made to call this after addEvent is called.\n */\n public initialiseState(stateEvents: MatrixEvent[], { timelineWasEmpty }: IInitialiseStateOptions = {}): void {\n if (this.events.length > 0) {\n throw new Error(\"Cannot initialise state after events are added\");\n }\n\n this.startState?.setStateEvents(stateEvents, { timelineWasEmpty });\n this.endState?.setStateEvents(stateEvents, { timelineWasEmpty });\n }\n\n /**\n * Forks the (live) timeline, taking ownership of the existing directional state of this timeline.\n * All attached listeners will keep receiving state updates from the new live timeline state.\n * The end state of this timeline gets replaced with an independent copy of the current RoomState,\n * and will need a new pagination token if it ever needs to paginate forwards.\n\n * @param direction - EventTimeline.BACKWARDS to get the state at the\n * start of the timeline; EventTimeline.FORWARDS to get the state at the end\n * of the timeline.\n *\n * @returns the new timeline\n */\n public forkLive(direction: Direction): EventTimeline {\n const forkState = this.getState(direction);\n const timeline = new EventTimeline(this.eventTimelineSet);\n timeline.startState = forkState?.clone();\n // Now clobber the end state of the new live timeline with that from the\n // previous live timeline. It will be identical except that we'll keep\n // using the same RoomMember objects for the 'live' set of members with any\n // listeners still attached\n timeline.endState = forkState;\n // Firstly, we just stole the current timeline's end state, so it needs a new one.\n // Make an immutable copy of the state so back pagination will get the correct sentinels.\n this.endState = forkState?.clone();\n return timeline;\n }\n\n /**\n * Creates an independent timeline, inheriting the directional state from this timeline.\n *\n * @param direction - EventTimeline.BACKWARDS to get the state at the\n * start of the timeline; EventTimeline.FORWARDS to get the state at the end\n * of the timeline.\n *\n * @returns the new timeline\n */\n public fork(direction: Direction): EventTimeline {\n const forkState = this.getState(direction);\n const timeline = new EventTimeline(this.eventTimelineSet);\n timeline.startState = forkState?.clone();\n timeline.endState = forkState?.clone();\n return timeline;\n }\n\n /**\n * Get the ID of the room for this timeline\n * @returns room ID\n */\n public getRoomId(): string | null {\n return this.roomId;\n }\n\n /**\n * Get the filter for this timeline's timelineSet (if any)\n * @returns filter\n */\n public getFilter(): Filter | undefined {\n return this.eventTimelineSet.getFilter();\n }\n\n /**\n * Get the timelineSet for this timeline\n * @returns timelineSet\n */\n public getTimelineSet(): EventTimelineSet {\n return this.eventTimelineSet;\n }\n\n /**\n * Get the base index.\n *\n * <p>This is an index which is incremented when events are prepended to the\n * timeline. An individual event therefore stays at the same index in the array\n * relative to the base index (although note that a given event's index may\n * well be less than the base index, thus giving that event a negative relative\n * index).\n */\n public getBaseIndex(): number {\n return this.baseIndex;\n }\n\n /**\n * Get the list of events in this context\n *\n * @returns An array of MatrixEvents\n */\n public getEvents(): MatrixEvent[] {\n return this.events;\n }\n\n /**\n * Get the room state at the start/end of the timeline\n *\n * @param direction - EventTimeline.BACKWARDS to get the state at the\n * start of the timeline; EventTimeline.FORWARDS to get the state at the end\n * of the timeline.\n *\n * @returns state at the start/end of the timeline\n */\n public getState(direction: Direction): RoomState | undefined {\n if (direction == EventTimeline.BACKWARDS) {\n return this.startState;\n } else if (direction == EventTimeline.FORWARDS) {\n return this.endState;\n } else {\n throw new Error(\"Invalid direction '\" + direction + \"'\");\n }\n }\n\n /**\n * Get a pagination token\n *\n * @param direction - EventTimeline.BACKWARDS to get the pagination\n * token for going backwards in time; EventTimeline.FORWARDS to get the\n * pagination token for going forwards in time.\n *\n * @returns pagination token\n */\n public getPaginationToken(direction: Direction): string | null {\n if (this.roomId) {\n return this.getState(direction)!.paginationToken;\n } else if (direction === Direction.Backward) {\n return this.startToken;\n } else {\n return this.endToken;\n }\n }\n\n /**\n * Set a pagination token\n *\n * @param token - pagination token\n *\n * @param direction - EventTimeline.BACKWARDS to set the pagination\n * token for going backwards in time; EventTimeline.FORWARDS to set the\n * pagination token for going forwards in time.\n */\n public setPaginationToken(token: string | null, direction: Direction): void {\n if (this.roomId) {\n this.getState(direction)!.paginationToken = token;\n } else if (direction === Direction.Backward) {\n this.startToken = token;\n } else {\n this.endToken = token;\n }\n }\n\n /**\n * Get the next timeline in the series\n *\n * @param direction - EventTimeline.BACKWARDS to get the previous\n * timeline; EventTimeline.FORWARDS to get the next timeline.\n *\n * @returns previous or following timeline, if they have been\n * joined up.\n */\n public getNeighbouringTimeline(direction: Direction): EventTimeline | null {\n if (direction == EventTimeline.BACKWARDS) {\n return this.prevTimeline;\n } else if (direction == EventTimeline.FORWARDS) {\n return this.nextTimeline;\n } else {\n throw new Error(\"Invalid direction '\" + direction + \"'\");\n }\n }\n\n /**\n * Set the next timeline in the series\n *\n * @param neighbour - previous/following timeline\n *\n * @param direction - EventTimeline.BACKWARDS to set the previous\n * timeline; EventTimeline.FORWARDS to set the next timeline.\n *\n * @throws Error if an attempt is made to set the neighbouring timeline when\n * it is already set.\n */\n public setNeighbouringTimeline(neighbour: EventTimeline, direction: Direction): void {\n if (this.getNeighbouringTimeline(direction)) {\n throw new Error(\n \"timeline already has a neighbouring timeline - \" +\n \"cannot reset neighbour (direction: \" +\n direction +\n \")\",\n );\n }\n\n if (direction == EventTimeline.BACKWARDS) {\n this.prevTimeline = neighbour;\n } else if (direction == EventTimeline.FORWARDS) {\n this.nextTimeline = neighbour;\n } else {\n throw new Error(\"Invalid direction '\" + direction + \"'\");\n }\n\n // make sure we don't try to paginate this timeline\n this.setPaginationToken(null, direction);\n }\n\n /**\n * Add a new event to the timeline, and update the state\n *\n * @param event - new event\n * @param options - addEvent options\n */\n public addEvent(\n event: MatrixEvent,\n { toStartOfTimeline, roomState, timelineWasEmpty, addToState }: IAddEventOptions,\n ): void {\n if (!roomState) {\n roomState = toStartOfTimeline ? this.startState : this.endState;\n }\n\n const timelineSet = this.getTimelineSet();\n\n if (timelineSet.room) {\n EventTimeline.setEventMetadata(event, roomState!, toStartOfTimeline);\n\n // modify state but only on unfiltered timelineSets\n if (addToState && event.isState() && timelineSet.room.getUnfilteredTimelineSet() === timelineSet) {\n roomState?.setStateEvents([event], { timelineWasEmpty });\n // it is possible that the act of setting the state event means we\n // can set more metadata (specifically sender/target props), so try\n // it again if the prop wasn't previously set. It may also mean that\n // the sender/target is updated (if the event set was a room member event)\n // so we want to use the *updated* member (new avatar/name) instead.\n //\n // However, we do NOT want to do this on member events if we're going\n // back in time, else we'll set the .sender value for BEFORE the given\n // member event, whereas we want to set the .sender value for the ACTUAL\n // member event itself.\n if (!event.sender || (event.getType() === EventType.RoomMember && !toStartOfTimeline)) {\n EventTimeline.setEventMetadata(event, roomState!, toStartOfTimeline);\n }\n }\n }\n\n let insertIndex: number;\n\n if (toStartOfTimeline) {\n insertIndex = 0;\n } else {\n insertIndex = this.events.length;\n }\n\n this.events.splice(insertIndex, 0, event); // insert element\n if (toStartOfTimeline) {\n this.baseIndex++;\n }\n }\n\n /**\n * Insert a new event into the timeline, and update the state.\n *\n * TEMPORARY: until we have recursive relations, we need this function\n * to exist to allow us to insert events in timeline order, which is our\n * best guess for Sync Order.\n * This is a copy of addEvent above, modified to allow inserting an event at\n * a specific index.\n *\n * @internal\n */\n public insertEvent(event: MatrixEvent, insertIndex: number, roomState: RoomState, addToState: boolean): void {\n const timelineSet = this.getTimelineSet();\n\n if (timelineSet.room) {\n EventTimeline.setEventMetadata(event, roomState, false);\n\n // modify state but only on unfiltered timelineSets\n if (addToState && event.isState() && timelineSet.room.getUnfilteredTimelineSet() === timelineSet) {\n roomState.setStateEvents([event], {});\n // it is possible that the act of setting the state event means we\n // can set more metadata (specifically sender/target props), so try\n // it again if the prop wasn't previously set. It may also mean that\n // the sender/target is updated (if the event set was a room member event)\n // so we want to use the *updated* member (new avatar/name) instead.\n //\n // However, we do NOT want to do this on member events if we're going\n // back in time, else we'll set the .sender value for BEFORE the given\n // member event, whereas we want to set the .sender value for the ACTUAL\n // member event itself.\n if (!event.sender || event.getType() === EventType.RoomMember) {\n EventTimeline.setEventMetadata(event, roomState, false);\n }\n }\n }\n\n this.events.splice(insertIndex, 0, event); // insert element\n }\n\n /**\n * Remove an event from the timeline\n *\n * @param eventId - ID of event to be removed\n * @returns removed event, or null if not found\n */\n public removeEvent(eventId: string): MatrixEvent | null {\n for (let i = this.events.length - 1; i >= 0; i--) {\n const ev = this.events[i];\n if (ev.getId() == eventId) {\n this.events.splice(i, 1);\n if (i < this.baseIndex) {\n this.baseIndex--;\n }\n return ev;\n }\n }\n return null;\n }\n\n /**\n * Return a string to identify this timeline, for debugging\n *\n * @returns name for this timeline\n */\n public toString(): string {\n return this.name;\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
1
|
+
{"version":3,"file":"event-timeline.js","names":["RoomState","EventType","Direction","EventTimeline","setEventMetadata","event","stateContext","toStartOfTimeline","setMetadata","constructor","eventTimelineSet","_eventTimelineSet$roo","_eventTimelineSet$roo2","_defineProperty","Backward","Forward","roomId","room","startState","endState","paginationRequests","b","f","name","Date","toISOString","initialiseState","stateEvents","_this$startState","_this$endState","timelineWasEmpty","arguments","length","undefined","events","Error","setStateEvents","forkLive","direction","forkState","getState","timeline","clone","fork","getRoomId","getFilter","getTimelineSet","getBaseIndex","baseIndex","getEvents","BACKWARDS","FORWARDS","getPaginationToken","paginationToken","startToken","endToken","setPaginationToken","token","getNeighbouringTimeline","prevTimeline","nextTimeline","setNeighbouringTimeline","neighbour","addEvent","_ref","roomState","addToState","timelineSet","isState","getUnfilteredTimelineSet","_roomState","sender","getType","RoomMember","insertIndex","splice","insertEvent","removeEvent","eventId","i","ev","getId","toString"],"sources":["../../src/models/event-timeline.ts"],"sourcesContent":["/*\nCopyright 2016 - 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { IMarkerFoundOptions, RoomState } from \"./room-state.ts\";\nimport { EventTimelineSet } from \"./event-timeline-set.ts\";\nimport { MatrixEvent } from \"./event.ts\";\nimport { Filter } from \"../filter.ts\";\nimport { EventType } from \"../@types/event.ts\";\n\nexport interface IInitialiseStateOptions extends Pick<IMarkerFoundOptions, \"timelineWasEmpty\"> {\n // This is a separate interface without any extra stuff currently added on\n // top of `IMarkerFoundOptions` just because it feels like they have\n // different concerns. One shouldn't necessarily look to add to\n // `IMarkerFoundOptions` just because they want to add an extra option to\n // `initialiseState`.\n}\n\nexport interface IAddEventOptions extends Pick<IMarkerFoundOptions, \"timelineWasEmpty\"> {\n /** Whether to insert the new event at the start of the timeline where the\n * oldest events are (timeline is in chronological order, oldest to most\n * recent) */\n toStartOfTimeline: boolean;\n /** The state events to reconcile metadata from */\n roomState?: RoomState;\n /** Whether to add timeline events to the state as was done in legacy sync v2.\n * If true then timeline events will be added to the state.\n * In sync v2 with org.matrix.msc4222.use_state_after and simplified sliding sync,\n * all state arrives explicitly and timeline events should not be added. */\n addToState: boolean;\n}\n\nexport enum Direction {\n Backward = \"b\",\n Forward = \"f\",\n}\n\nexport class EventTimeline {\n /**\n * Symbolic constant for methods which take a 'direction' argument:\n * refers to the start of the timeline, or backwards in time.\n */\n public static readonly BACKWARDS = Direction.Backward;\n\n /**\n * Symbolic constant for methods which take a 'direction' argument:\n * refers to the end of the timeline, or forwards in time.\n */\n public static readonly FORWARDS = Direction.Forward;\n\n /**\n * Static helper method to set sender and target properties\n *\n * @param event - the event whose metadata is to be set\n * @param stateContext - the room state to be queried\n * @param toStartOfTimeline - if true the event's forwardLooking flag is set false\n */\n public static setEventMetadata(event: MatrixEvent, stateContext: RoomState, toStartOfTimeline: boolean): void {\n event.setMetadata(stateContext, toStartOfTimeline);\n }\n\n private readonly roomId: string | null;\n private readonly name: string;\n private events: MatrixEvent[] = [];\n private baseIndex = 0;\n\n private startState?: RoomState;\n private endState?: RoomState;\n // If we have a roomId then we delegate pagination token storage to the room state objects `startState` and\n // `endState`, but for things like the notification timeline which mix multiple rooms we store the tokens ourselves.\n private startToken: string | null = null;\n private endToken: string | null = null;\n\n private prevTimeline: EventTimeline | null = null;\n private nextTimeline: EventTimeline | null = null;\n public paginationRequests: Record<Direction, Promise<boolean> | null> = {\n [Direction.Backward]: null,\n [Direction.Forward]: null,\n };\n\n /**\n * Construct a new EventTimeline\n *\n * <p>An EventTimeline represents a contiguous sequence of events in a room.\n *\n * <p>As well as keeping track of the events themselves, it stores the state of\n * the room at the beginning and end of the timeline, and pagination tokens for\n * going backwards and forwards in the timeline.\n *\n * <p>In order that clients can meaningfully maintain an index into a timeline,\n * the EventTimeline object tracks a 'baseIndex'. This starts at zero, but is\n * incremented when events are prepended to the timeline. The index of an event\n * relative to baseIndex therefore remains constant.\n *\n * <p>Once a timeline joins up with its neighbour, they are linked together into a\n * doubly-linked list.\n *\n * @param eventTimelineSet - the set of timelines this is part of\n */\n public constructor(private readonly eventTimelineSet: EventTimelineSet) {\n this.roomId = eventTimelineSet.room?.roomId ?? null;\n if (this.roomId) {\n this.startState = new RoomState(this.roomId);\n this.endState = new RoomState(this.roomId);\n }\n\n // this is used by client.js\n this.paginationRequests = { b: null, f: null };\n\n this.name = this.roomId + \":\" + new Date().toISOString();\n }\n\n /**\n * Initialise the start and end state with the given events\n *\n * <p>This can only be called before any events are added.\n *\n * @param stateEvents - list of state events to initialise the\n * state with.\n * @throws Error if an attempt is made to call this after addEvent is called.\n */\n public initialiseState(stateEvents: MatrixEvent[], { timelineWasEmpty }: IInitialiseStateOptions = {}): void {\n if (this.events.length > 0) {\n throw new Error(\"Cannot initialise state after events are added\");\n }\n\n this.startState?.setStateEvents(stateEvents, { timelineWasEmpty });\n this.endState?.setStateEvents(stateEvents, { timelineWasEmpty });\n }\n\n /**\n * Forks the (live) timeline, taking ownership of the existing directional state of this timeline.\n * All attached listeners will keep receiving state updates from the new live timeline state.\n * The end state of this timeline gets replaced with an independent copy of the current RoomState,\n * and will need a new pagination token if it ever needs to paginate forwards.\n\n * @param direction - EventTimeline.BACKWARDS to get the state at the\n * start of the timeline; EventTimeline.FORWARDS to get the state at the end\n * of the timeline.\n *\n * @returns the new timeline\n */\n public forkLive(direction: Direction): EventTimeline {\n const forkState = this.getState(direction);\n const timeline = new EventTimeline(this.eventTimelineSet);\n timeline.startState = forkState?.clone();\n // Now clobber the end state of the new live timeline with that from the\n // previous live timeline. It will be identical except that we'll keep\n // using the same RoomMember objects for the 'live' set of members with any\n // listeners still attached\n timeline.endState = forkState;\n // Firstly, we just stole the current timeline's end state, so it needs a new one.\n // Make an immutable copy of the state so back pagination will get the correct sentinels.\n this.endState = forkState?.clone();\n return timeline;\n }\n\n /**\n * Creates an independent timeline, inheriting the directional state from this timeline.\n *\n * @param direction - EventTimeline.BACKWARDS to get the state at the\n * start of the timeline; EventTimeline.FORWARDS to get the state at the end\n * of the timeline.\n *\n * @returns the new timeline\n */\n public fork(direction: Direction): EventTimeline {\n const forkState = this.getState(direction);\n const timeline = new EventTimeline(this.eventTimelineSet);\n timeline.startState = forkState?.clone();\n timeline.endState = forkState?.clone();\n return timeline;\n }\n\n /**\n * Get the ID of the room for this timeline\n * @returns room ID\n */\n public getRoomId(): string | null {\n return this.roomId;\n }\n\n /**\n * Get the filter for this timeline's timelineSet (if any)\n * @returns filter\n */\n public getFilter(): Filter | undefined {\n return this.eventTimelineSet.getFilter();\n }\n\n /**\n * Get the timelineSet for this timeline\n * @returns timelineSet\n */\n public getTimelineSet(): EventTimelineSet {\n return this.eventTimelineSet;\n }\n\n /**\n * Get the base index.\n *\n * <p>This is an index which is incremented when events are prepended to the\n * timeline. An individual event therefore stays at the same index in the array\n * relative to the base index (although note that a given event's index may\n * well be less than the base index, thus giving that event a negative relative\n * index).\n */\n public getBaseIndex(): number {\n return this.baseIndex;\n }\n\n /**\n * Get the list of events in this context\n *\n * @returns An array of MatrixEvents\n */\n public getEvents(): MatrixEvent[] {\n return this.events;\n }\n\n /**\n * Get the room state at the start/end of the timeline\n *\n * @param direction - EventTimeline.BACKWARDS to get the state at the\n * start of the timeline; EventTimeline.FORWARDS to get the state at the end\n * of the timeline.\n *\n * @returns state at the start/end of the timeline\n */\n public getState(direction: Direction): RoomState | undefined {\n if (direction == EventTimeline.BACKWARDS) {\n return this.startState;\n } else if (direction == EventTimeline.FORWARDS) {\n return this.endState;\n } else {\n throw new Error(\"Invalid direction '\" + direction + \"'\");\n }\n }\n\n /**\n * Get a pagination token\n *\n * @param direction - EventTimeline.BACKWARDS to get the pagination\n * token for going backwards in time; EventTimeline.FORWARDS to get the\n * pagination token for going forwards in time.\n *\n * @returns pagination token\n */\n public getPaginationToken(direction: Direction): string | null {\n if (this.roomId) {\n return this.getState(direction)!.paginationToken;\n } else if (direction === Direction.Backward) {\n return this.startToken;\n } else {\n return this.endToken;\n }\n }\n\n /**\n * Set a pagination token\n *\n * @param token - pagination token\n *\n * @param direction - EventTimeline.BACKWARDS to set the pagination\n * token for going backwards in time; EventTimeline.FORWARDS to set the\n * pagination token for going forwards in time.\n */\n public setPaginationToken(token: string | null, direction: Direction): void {\n if (this.roomId) {\n this.getState(direction)!.paginationToken = token;\n } else if (direction === Direction.Backward) {\n this.startToken = token;\n } else {\n this.endToken = token;\n }\n }\n\n /**\n * Get the next timeline in the series\n *\n * @param direction - EventTimeline.BACKWARDS to get the previous\n * timeline; EventTimeline.FORWARDS to get the next timeline.\n *\n * @returns previous or following timeline, if they have been\n * joined up.\n */\n public getNeighbouringTimeline(direction: Direction): EventTimeline | null {\n if (direction == EventTimeline.BACKWARDS) {\n return this.prevTimeline;\n } else if (direction == EventTimeline.FORWARDS) {\n return this.nextTimeline;\n } else {\n throw new Error(\"Invalid direction '\" + direction + \"'\");\n }\n }\n\n /**\n * Set the next timeline in the series\n *\n * @param neighbour - previous/following timeline\n *\n * @param direction - EventTimeline.BACKWARDS to set the previous\n * timeline; EventTimeline.FORWARDS to set the next timeline.\n *\n * @throws Error if an attempt is made to set the neighbouring timeline when\n * it is already set.\n */\n public setNeighbouringTimeline(neighbour: EventTimeline, direction: Direction): void {\n if (this.getNeighbouringTimeline(direction)) {\n throw new Error(\n \"timeline already has a neighbouring timeline - \" +\n \"cannot reset neighbour (direction: \" +\n direction +\n \")\",\n );\n }\n\n if (direction == EventTimeline.BACKWARDS) {\n this.prevTimeline = neighbour;\n } else if (direction == EventTimeline.FORWARDS) {\n this.nextTimeline = neighbour;\n } else {\n throw new Error(\"Invalid direction '\" + direction + \"'\");\n }\n\n // make sure we don't try to paginate this timeline\n this.setPaginationToken(null, direction);\n }\n\n /**\n * Add a new event to the timeline, and update the state\n *\n * @param event - new event\n * @param options - addEvent options\n */\n public addEvent(\n event: MatrixEvent,\n { toStartOfTimeline, roomState, timelineWasEmpty, addToState }: IAddEventOptions,\n ): void {\n if (!roomState) {\n roomState = toStartOfTimeline ? this.startState : this.endState;\n }\n\n const timelineSet = this.getTimelineSet();\n\n if (timelineSet.room) {\n EventTimeline.setEventMetadata(event, roomState!, toStartOfTimeline);\n\n // modify state but only on unfiltered timelineSets\n if (addToState && event.isState() && timelineSet.room.getUnfilteredTimelineSet() === timelineSet) {\n roomState?.setStateEvents([event], { timelineWasEmpty });\n // it is possible that the act of setting the state event means we\n // can set more metadata (specifically sender/target props), so try\n // it again if the prop wasn't previously set. It may also mean that\n // the sender/target is updated (if the event set was a room member event)\n // so we want to use the *updated* member (new avatar/name) instead.\n //\n // However, we do NOT want to do this on member events if we're going\n // back in time, else we'll set the .sender value for BEFORE the given\n // member event, whereas we want to set the .sender value for the ACTUAL\n // member event itself.\n if (!event.sender || (event.getType() === EventType.RoomMember && !toStartOfTimeline)) {\n EventTimeline.setEventMetadata(event, roomState!, toStartOfTimeline);\n }\n }\n }\n\n let insertIndex: number;\n\n if (toStartOfTimeline) {\n insertIndex = 0;\n } else {\n insertIndex = this.events.length;\n }\n\n this.events.splice(insertIndex, 0, event); // insert element\n if (toStartOfTimeline) {\n this.baseIndex++;\n }\n }\n\n /**\n * Insert a new event into the timeline, and update the state.\n *\n * TEMPORARY: until we have recursive relations, we need this function\n * to exist to allow us to insert events in timeline order, which is our\n * best guess for Sync Order.\n * This is a copy of addEvent above, modified to allow inserting an event at\n * a specific index.\n *\n * @internal\n */\n public insertEvent(event: MatrixEvent, insertIndex: number, roomState: RoomState, addToState: boolean): void {\n const timelineSet = this.getTimelineSet();\n\n if (timelineSet.room) {\n EventTimeline.setEventMetadata(event, roomState, false);\n\n // modify state but only on unfiltered timelineSets\n if (addToState && event.isState() && timelineSet.room.getUnfilteredTimelineSet() === timelineSet) {\n roomState.setStateEvents([event], {});\n // it is possible that the act of setting the state event means we\n // can set more metadata (specifically sender/target props), so try\n // it again if the prop wasn't previously set. It may also mean that\n // the sender/target is updated (if the event set was a room member event)\n // so we want to use the *updated* member (new avatar/name) instead.\n //\n // However, we do NOT want to do this on member events if we're going\n // back in time, else we'll set the .sender value for BEFORE the given\n // member event, whereas we want to set the .sender value for the ACTUAL\n // member event itself.\n if (!event.sender || event.getType() === EventType.RoomMember) {\n EventTimeline.setEventMetadata(event, roomState, false);\n }\n }\n }\n\n this.events.splice(insertIndex, 0, event); // insert element\n }\n\n /**\n * Remove an event from the timeline\n *\n * @param eventId - ID of event to be removed\n * @returns removed event, or null if not found\n */\n public removeEvent(eventId: string): MatrixEvent | null {\n for (let i = this.events.length - 1; i >= 0; i--) {\n const ev = this.events[i];\n if (ev.getId() == eventId) {\n this.events.splice(i, 1);\n if (i < this.baseIndex) {\n this.baseIndex--;\n }\n return ev;\n }\n }\n return null;\n }\n\n /**\n * Return a string to identify this timeline, for debugging\n *\n * @returns name for this timeline\n */\n public toString(): string {\n return this.name;\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
package/lib/models/event.d.ts
CHANGED
@@ -13,6 +13,7 @@ import { EventStatus } from "./event-status.ts";
|
|
13
13
|
import { IAnnotatedPushRule } from "../@types/PushRules.ts";
|
14
14
|
import { Room } from "./room.ts";
|
15
15
|
import { Membership } from "../@types/membership.ts";
|
16
|
+
import { RoomState } from "./room-state.ts";
|
16
17
|
export { EventStatus } from "./event-status.ts";
|
17
18
|
export interface IContent {
|
18
19
|
[key: string]: any;
|
@@ -169,7 +170,8 @@ export declare enum MatrixEventEvent {
|
|
169
170
|
LocalEventIdReplaced = "Event.localEventIdReplaced",
|
170
171
|
Status = "Event.status",
|
171
172
|
Replaced = "Event.replaced",
|
172
|
-
RelationsCreated = "Event.relationsCreated"
|
173
|
+
RelationsCreated = "Event.relationsCreated",
|
174
|
+
SentinelUpdated = "Event.sentinelUpdated"
|
173
175
|
}
|
174
176
|
export type MatrixEventEmittedEvents = MatrixEventEvent | ThreadEvent.Update;
|
175
177
|
export type MatrixEventHandlerMap = {
|
@@ -180,6 +182,7 @@ export type MatrixEventHandlerMap = {
|
|
180
182
|
[MatrixEventEvent.Status]: (event: MatrixEvent, status: EventStatus | null) => void;
|
181
183
|
[MatrixEventEvent.Replaced]: (event: MatrixEvent) => void;
|
182
184
|
[MatrixEventEvent.RelationsCreated]: (relationType: string, eventType: string) => void;
|
185
|
+
[MatrixEventEvent.SentinelUpdated]: () => void;
|
183
186
|
} & Pick<ThreadEventHandlerMap, ThreadEvent.Update>;
|
184
187
|
export declare class MatrixEvent extends TypedEventEmitter<MatrixEventEmittedEvents, MatrixEventHandlerMap> {
|
185
188
|
event: Partial<IEvent>;
|
@@ -218,6 +221,13 @@ export declare class MatrixEvent extends TypedEventEmitter<MatrixEventEmittedEve
|
|
218
221
|
* Should be read-only
|
219
222
|
*/
|
220
223
|
target: RoomMember | null;
|
224
|
+
/**
|
225
|
+
* Update the sentinels and forwardLooking flag for this event.
|
226
|
+
* @param stateContext - the room state to be queried
|
227
|
+
* @param toStartOfTimeline - if true the event's forwardLooking flag is set false
|
228
|
+
* @internal
|
229
|
+
*/
|
230
|
+
setMetadata(stateContext: RoomState, toStartOfTimeline: boolean): void;
|
221
231
|
/**
|
222
232
|
* The sending status of the event.
|
223
233
|
* @privateRemarks
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"event.d.ts","sourceRoot":"","sources":["../../src/models/event.ts"],"names":[],"mappings":"AAgBA;;;GAGG;AAEH,OAAO,EAAE,eAAe,EAAoB,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAEhF,OAAO,EAEH,SAAS,EACT,OAAO,EACP,YAAY,EAEZ,wBAAwB,EAE3B,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,MAAM,EAAwB,WAAW,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AAC/F,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAErD,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEjC,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;
|
1
|
+
{"version":3,"file":"event.d.ts","sourceRoot":"","sources":["../../src/models/event.ts"],"names":[],"mappings":"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"}
|
package/lib/models/event.js
CHANGED
@@ -62,9 +62,57 @@ export var MatrixEventEvent = /*#__PURE__*/function (MatrixEventEvent) {
|
|
62
62
|
MatrixEventEvent["Status"] = "Event.status";
|
63
63
|
MatrixEventEvent["Replaced"] = "Event.replaced";
|
64
64
|
MatrixEventEvent["RelationsCreated"] = "Event.relationsCreated";
|
65
|
+
MatrixEventEvent["SentinelUpdated"] = "Event.sentinelUpdated";
|
65
66
|
return MatrixEventEvent;
|
66
67
|
}({});
|
67
68
|
export class MatrixEvent extends TypedEventEmitter {
|
69
|
+
/**
|
70
|
+
* Update the sentinels and forwardLooking flag for this event.
|
71
|
+
* @param stateContext - the room state to be queried
|
72
|
+
* @param toStartOfTimeline - if true the event's forwardLooking flag is set false
|
73
|
+
* @internal
|
74
|
+
*/
|
75
|
+
setMetadata(stateContext, toStartOfTimeline) {
|
76
|
+
var _this$sender, _this$target;
|
77
|
+
// If an event is an m.room.member state event then we should set the sentinels again in case setEventMetadata
|
78
|
+
// was already called before the state was applied and thus the sentinel points at the member from before this event.
|
79
|
+
var affectsSelf = this.isState() && this.getType() === EventType.RoomMember && this.getSender() === this.getStateKey();
|
80
|
+
var changed = false;
|
81
|
+
// When we try to generate a sentinel member before we have that member
|
82
|
+
// in the members object, we still generate a sentinel but it doesn't
|
83
|
+
// have a membership event, so test to see if events.member is set. We
|
84
|
+
// check this to avoid overriding non-sentinel members by sentinel ones
|
85
|
+
// when adding the event to a filtered timeline
|
86
|
+
if (affectsSelf || !((_this$sender = this.sender) !== null && _this$sender !== void 0 && (_this$sender = _this$sender.events) !== null && _this$sender !== void 0 && _this$sender.member)) {
|
87
|
+
var newSender = stateContext.getSentinelMember(this.getSender());
|
88
|
+
if (newSender !== this.sender) changed = true;
|
89
|
+
this.sender = newSender;
|
90
|
+
}
|
91
|
+
if (affectsSelf || !((_this$target = this.target) !== null && _this$target !== void 0 && (_this$target = _this$target.events) !== null && _this$target !== void 0 && _this$target.member) && this.getType() === EventType.RoomMember) {
|
92
|
+
var newTarget = stateContext.getSentinelMember(this.getStateKey());
|
93
|
+
if (newTarget !== this.target) changed = true;
|
94
|
+
this.target = newTarget;
|
95
|
+
}
|
96
|
+
if (this.isState()) {
|
97
|
+
// room state has no concept of 'old' or 'current', but we want the
|
98
|
+
// room state to regress back to previous values if toStartOfTimeline
|
99
|
+
// is set, which means inspecting prev_content if it exists. This
|
100
|
+
// is done by toggling the forwardLooking flag.
|
101
|
+
if (toStartOfTimeline) {
|
102
|
+
this.forwardLooking = false;
|
103
|
+
}
|
104
|
+
}
|
105
|
+
if (changed) {
|
106
|
+
this.emit(MatrixEventEvent.SentinelUpdated);
|
107
|
+
}
|
108
|
+
}
|
109
|
+
|
110
|
+
/**
|
111
|
+
* The sending status of the event.
|
112
|
+
* @privateRemarks
|
113
|
+
* Should be read-only
|
114
|
+
*/
|
115
|
+
|
68
116
|
/**
|
69
117
|
* Construct a Matrix Event object
|
70
118
|
*
|
@@ -148,11 +196,6 @@ export class MatrixEvent extends TypedEventEmitter {
|
|
148
196
|
* Should be read-only
|
149
197
|
*/
|
150
198
|
_defineProperty(this, "target", null);
|
151
|
-
/**
|
152
|
-
* The sending status of the event.
|
153
|
-
* @privateRemarks
|
154
|
-
* Should be read-only
|
155
|
-
*/
|
156
199
|
_defineProperty(this, "status", null);
|
157
200
|
/**
|
158
201
|
* most recent error associated with sending the event, if any
|