/* Copyright 2022 The Matrix.org Foundation C.I.C. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. */ import { MatrixError } from "./errors"; export interface IHttpOpts { fetchFn?: typeof global.fetch; baseUrl: string; idBaseUrl?: string; prefix: string; extraParams?: Record; accessToken?: string; useAuthorizationHeader?: boolean; // defaults to true onlyData?: boolean; localTimeoutMs?: number; } export interface IRequestOpts { /** * The alternative base url to use. * If not specified, uses this.opts.baseUrl */ baseUrl?: string; /** * The full prefix to use e.g. * "/_matrix/client/v2_alpha". If not specified, uses this.opts.prefix. */ prefix?: string; /** * map of additional request headers */ headers?: Record; abortSignal?: AbortSignal; /** * The maximum amount of time to wait before * timing out the request. If not specified, there is no timeout. */ localTimeoutMs?: number; keepAlive?: boolean; // defaults to false json?: boolean; // defaults to true // Set to true to prevent the request function from emitting a Session.logged_out event. // This is intended for use on endpoints where M_UNKNOWN_TOKEN is a valid/notable error response, // such as with token refreshes. inhibitLogoutEmit?: boolean; } export interface IContentUri { base: string; path: string; params: { // eslint-disable-next-line camelcase access_token: string; }; } export enum HttpApiEvent { SessionLoggedOut = "Session.logged_out", NoConsent = "no_consent", } export type HttpApiEventHandlerMap = { /** * Fires whenever the login session the JS SDK is using is no * longer valid and the user must log in again. * NB. This only fires when action is required from the user, not * when then login session can be renewed by using a refresh token. * @example * ``` * matrixClient.on("Session.logged_out", function(errorObj){ * // show the login screen * }); * ``` */ [HttpApiEvent.SessionLoggedOut]: (err: MatrixError) => void; /** * Fires when the JS SDK receives a M_CONSENT_NOT_GIVEN error in response * to a HTTP request. * @example * ``` * matrixClient.on("no_consent", function(message, contentUri) { * console.info(message + ' Go to ' + contentUri); * }); * ``` */ [HttpApiEvent.NoConsent]: (message: string, consentUri: string) => void; }; export interface UploadProgress { loaded: number; total: number; } export interface UploadOpts { /** * Name to give the file on the server. Defaults to file.name. */ name?: string; /** * Content-type for the upload. Defaults to * file.type, or applicaton/octet-stream. */ type?: string; /** * if false will not send the filename, * e.g for encrypted file uploads where filename leaks are undesirable. * Defaults to true. */ includeFilename?: boolean; /** * Optional. Called when a chunk of * data has been uploaded, with an object containing the fields `loaded` * (number of bytes transferred) and `total` (total size, if known). */ progressHandler?(progress: UploadProgress): void; abortController?: AbortController; } export interface Upload { loaded: number; total: number; promise: Promise; abortController: AbortController; } export interface UploadResponse { // eslint-disable-next-line camelcase content_uri: string; } export type FileType = XMLHttpRequestBodyInit;