react-native-appwrite 0.14.0 → 0.15.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/dist/cjs/sdk.js +1 -1
- package/dist/cjs/sdk.js.map +1 -1
- package/dist/esm/sdk.js +1 -1
- package/dist/esm/sdk.js.map +1 -1
- package/package.json +1 -1
- package/src/client.ts +1 -1
- package/src/enums/execution-status.ts +6 -0
- package/src/enums/execution-trigger.ts +5 -0
- package/src/models.ts +5 -2
- package/types/enums/execution-status.d.ts +6 -0
- package/types/enums/execution-trigger.d.ts +5 -0
- package/types/models.d.ts +4 -2
package/dist/esm/sdk.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sdk.js","sources":["../../node_modules/tslib/tslib.es6.js","../../src/service.ts","../../src/client.ts","../../src/services/account.ts","../../src/services/avatars.ts","../../src/services/databases.ts","../../src/services/functions.ts","../../src/services/graphql.ts","../../src/services/locale.ts","../../src/services/messaging.ts","../../src/services/storage.ts","../../src/services/tables-db.ts","../../src/services/teams.ts","../../src/query.ts","../../src/permission.ts","../../src/role.ts","../../src/id.ts","../../src/enums/authenticator-type.ts","../../src/enums/authentication-factor.ts","../../src/enums/o-auth-provider.ts","../../src/enums/browser.ts","../../src/enums/credit-card.ts","../../src/enums/flag.ts","../../src/enums/execution-method.ts","../../src/enums/image-gravity.ts","../../src/enums/image-format.ts"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","import { Client } from './client';\nimport type { Payload } from './client';\n\nexport class Service {\n static CHUNK_SIZE = 5*1024*1024; // 5MB\n\n client: Client;\n\n constructor(client: Client) {\n this.client = client;\n }\n\n static flatten(data: Payload, prefix = ''): Payload {\n let output: Payload = {};\n\n for (const [key, value] of Object.entries(data)) {\n let finalKey = prefix ? prefix + '[' + key +']' : key;\n if (Array.isArray(value)) {\n output = { ...output, ...Service.flatten(value, finalKey) };\n } else {\n output[finalKey] = value;\n }\n }\n\n return output;\n }\n}","import { Models } from './models';\nimport { Service } from './service';\nimport { Platform } from 'react-native';\n\ntype Payload = {\n [key: string]: any;\n}\n\ntype Headers = {\n [key: string]: string;\n}\n\ntype RealtimeResponse = {\n type: 'error' | 'event' | 'connected' | 'response' | 'pong';\n data: RealtimeResponseAuthenticated | RealtimeResponseConnected | RealtimeResponseError | RealtimeResponseEvent<unknown> | undefined;\n}\n\ntype RealtimeRequest = {\n type: 'authentication';\n data: RealtimeRequestAuthenticate;\n}\n\nexport type RealtimeResponseEvent<T extends unknown> = {\n events: string[];\n channels: string[];\n timestamp: number;\n payload: T;\n}\n\ntype RealtimeResponseError = {\n code: number;\n message: string;\n}\n\ntype RealtimeResponseConnected = {\n channels: string[];\n user?: object;\n}\n\ntype RealtimeResponseAuthenticated = {\n to: string;\n success: boolean;\n user: object;\n}\n\ntype RealtimeRequestAuthenticate = {\n session: string;\n}\n\ntype Realtime = {\n socket?: WebSocket;\n\n /**\n * Timeout for reconnect operations.\n */\n timeout?: number;\n\n /**\n * Heartbeat interval for the realtime connection.\n */\n heartbeat?: number;\n\n url?: string;\n lastMessage?: RealtimeResponse;\n channels: Set<string>;\n subscriptions: Map<number, {\n channels: string[];\n callback: (payload: RealtimeResponseEvent<any>) => void\n }>;\n subscriptionsCounter: number;\n reconnect: boolean;\n reconnectAttempts: number;\n getTimeout: () => number;\n connect: () => void;\n createSocket: () => void;\n createHeartbeat: () => void;\n cleanUp: (channels: string[]) => void;\n onMessage: (event: MessageEvent) => void;\n}\n\nexport type UploadProgress = {\n $id: string;\n progress: number;\n sizeUploaded: number;\n chunksTotal: number;\n chunksUploaded: number;\n}\n\nclass AppwriteException extends Error {\n code: number;\n response: string;\n type: string;\n constructor(message: string, code: number = 0, type: string = '', response: string = '') {\n super(message);\n this.name = 'AppwriteException';\n this.message = message;\n this.code = code;\n this.type = type;\n this.response = response;\n }\n}\n\nclass Client {\n config = {\n endpoint: 'https://cloud.appwrite.io/v1',\n endpointRealtime: '',\n project: '',\n jwt: '',\n locale: '',\n session: '',\n devkey: '',\n platform: '',\n };\n headers: Headers = {\n 'x-sdk-name': 'React Native',\n 'x-sdk-platform': 'client',\n 'x-sdk-language': 'reactnative',\n 'x-sdk-version': '0.14.0',\n 'X-Appwrite-Response-Format': '1.8.0',\n };\n\n /**\n * Set Endpoint\n *\n * Your project endpoint\n *\n * @param {string} endpoint\n *\n * @returns {this}\n */\n setEndpoint(endpoint: string): this {\n if (!endpoint.startsWith('http://') && !endpoint.startsWith('https://')) {\n throw new AppwriteException('Invalid endpoint URL: ' + endpoint);\n }\n\n this.config.endpoint = endpoint;\n this.config.endpointRealtime = endpoint.replace('https://', 'wss://').replace('http://', 'ws://');\n\n return this;\n }\n\n /**\n * Set Realtime Endpoint\n *\n * @param {string} endpointRealtime\n *\n * @returns {this}\n */\n setEndpointRealtime(endpointRealtime: string): this {\n if (!endpointRealtime.startsWith('ws://') && !endpointRealtime.startsWith('wss://')) {\n throw new AppwriteException('Invalid realtime endpoint URL: ' + endpointRealtime);\n }\n\n this.config.endpointRealtime = endpointRealtime;\n return this;\n }\n\n /**\n * Set platform\n * \n * Set platform. Will be used as origin for all requests.\n * \n * @param {string} platform\n * @returns {this}\n */\n setPlatform(platform: string): this {\n this.config.platform = platform;\n\n return this;\n }\n\n /**\n * Set Project\n *\n * Your project ID\n *\n * @param value string\n *\n * @return {this}\n */\n setProject(value: string): this {\n this.headers['X-Appwrite-Project'] = value;\n this.config.project = value;\n return this;\n }\n\n /**\n * Set JWT\n *\n * Your secret JSON Web Token\n *\n * @param value string\n *\n * @return {this}\n */\n setJWT(value: string): this {\n this.headers['X-Appwrite-JWT'] = value;\n this.config.jwt = value;\n return this;\n }\n\n /**\n * Set Locale\n *\n * @param value string\n *\n * @return {this}\n */\n setLocale(value: string): this {\n this.headers['X-Appwrite-Locale'] = value;\n this.config.locale = value;\n return this;\n }\n\n /**\n * Set Session\n *\n * The user session to authenticate with\n *\n * @param value string\n *\n * @return {this}\n */\n setSession(value: string): this {\n this.headers['X-Appwrite-Session'] = value;\n this.config.session = value;\n return this;\n }\n\n /**\n * Set DevKey\n *\n * Your secret dev API key\n *\n * @param value string\n *\n * @return {this}\n */\n setDevKey(value: string): this {\n this.headers['X-Appwrite-Dev-Key'] = value;\n this.config.devkey = value;\n return this;\n }\n\n\n private realtime: Realtime = {\n socket: undefined,\n timeout: undefined,\n heartbeat: undefined,\n url: '',\n channels: new Set(),\n subscriptions: new Map(),\n subscriptionsCounter: 0,\n reconnect: true,\n reconnectAttempts: 0,\n lastMessage: undefined,\n connect: () => {\n clearTimeout(this.realtime.timeout);\n this.realtime.timeout = window?.setTimeout(() => {\n this.realtime.createSocket();\n }, 50);\n },\n getTimeout: () => {\n switch (true) {\n case this.realtime.reconnectAttempts < 5:\n return 1000;\n case this.realtime.reconnectAttempts < 15:\n return 5000;\n case this.realtime.reconnectAttempts < 100:\n return 10_000;\n default:\n return 60_000;\n }\n },\n createHeartbeat: () => {\n if (this.realtime.heartbeat) {\n clearTimeout(this.realtime.heartbeat);\n }\n\n this.realtime.heartbeat = window?.setInterval(() => {\n this.realtime.socket?.send(JSON.stringify({\n type: 'ping'\n }));\n }, 20_000);\n },\n createSocket: () => {\n if (this.realtime.channels.size < 1) {\n this.realtime.reconnect = false;\n this.realtime.socket?.close();\n return;\n }\n\n const channels = new URLSearchParams();\n channels.set('project', this.config.project);\n this.realtime.channels.forEach(channel => {\n channels.append('channels[]', channel);\n });\n\n const url = this.config.endpointRealtime + '/realtime?' + channels.toString();\n\n if (\n url !== this.realtime.url || // Check if URL is present\n !this.realtime.socket || // Check if WebSocket has not been created\n this.realtime.socket?.readyState > WebSocket.OPEN // Check if WebSocket is CLOSING (3) or CLOSED (4)\n ) {\n if (\n this.realtime.socket &&\n this.realtime.socket?.readyState < WebSocket.CLOSING // Close WebSocket if it is CONNECTING (0) or OPEN (1)\n ) {\n this.realtime.reconnect = false;\n this.realtime.socket.close();\n }\n\n this.realtime.url = url;\n // @ts-ignore\n this.realtime.socket = new WebSocket(url, undefined, {\n headers: {\n Origin: `appwrite-${Platform.OS}://${this.config.platform}`\n }\n });\n this.realtime.socket.addEventListener('message', this.realtime.onMessage);\n this.realtime.socket.addEventListener('open', _event => {\n this.realtime.reconnectAttempts = 0;\n this.realtime.createHeartbeat();\n });\n this.realtime.socket.addEventListener('close', event => {\n if (\n !this.realtime.reconnect ||\n (\n this.realtime?.lastMessage?.type === 'error' && // Check if last message was of type error\n (<RealtimeResponseError>this.realtime?.lastMessage.data).code === 1008 // Check for policy violation 1008\n )\n ) {\n this.realtime.reconnect = true;\n return;\n }\n\n const timeout = this.realtime.getTimeout();\n console.error(`Realtime got disconnected. Reconnect will be attempted in ${timeout / 1000} seconds.`, event.reason);\n\n setTimeout(() => {\n this.realtime.reconnectAttempts++;\n this.realtime.createSocket();\n }, timeout);\n })\n }\n },\n onMessage: (event) => {\n try {\n const message: RealtimeResponse = JSON.parse(event.data);\n this.realtime.lastMessage = message;\n switch (message.type) {\n case 'event':\n let data = <RealtimeResponseEvent<unknown>>message.data;\n if (data?.channels) {\n const isSubscribed = data.channels.some(channel => this.realtime.channels.has(channel));\n if (!isSubscribed) return;\n this.realtime.subscriptions.forEach(subscription => {\n if (data.channels.some(channel => subscription.channels.includes(channel))) {\n setTimeout(() => subscription.callback(data));\n }\n })\n }\n break;\n case 'pong':\n break; // Handle pong response if needed\n case 'error':\n throw message.data;\n default:\n break;\n }\n } catch (e) {\n console.error(e);\n }\n },\n cleanUp: channels => {\n this.realtime.channels.forEach(channel => {\n if (channels.includes(channel)) {\n let found = Array.from(this.realtime.subscriptions).some(([_key, subscription] )=> {\n return subscription.channels.includes(channel);\n })\n\n if (!found) {\n this.realtime.channels.delete(channel);\n }\n }\n })\n }\n }\n\n /**\n * Subscribes to Appwrite events and passes you the payload in realtime.\n * \n * @param {string|string[]} channels \n * Channel to subscribe - pass a single channel as a string or multiple with an array of strings.\n * \n * Possible channels are:\n * - account\n * - collections\n * - collections.[ID]\n * - collections.[ID].documents\n * - documents\n * - documents.[ID]\n * - files\n * - files.[ID]\n * - executions\n * - executions.[ID]\n * - functions.[ID]\n * - teams\n * - teams.[ID]\n * - memberships\n * - memberships.[ID]\n * @param {(payload: RealtimeMessage) => void} callback Is called on every realtime update.\n * @returns {() => void} Unsubscribes from events.\n */\n subscribe<T extends unknown>(channels: string | string[], callback: (payload: RealtimeResponseEvent<T>) => void): () => void {\n let channelArray = typeof channels === 'string' ? [channels] : channels;\n channelArray.forEach(channel => this.realtime.channels.add(channel));\n\n const counter = this.realtime.subscriptionsCounter++;\n this.realtime.subscriptions.set(counter, {\n channels: channelArray,\n callback\n });\n\n this.realtime.connect();\n\n return () => {\n this.realtime.subscriptions.delete(counter);\n this.realtime.cleanUp(channelArray);\n this.realtime.connect();\n }\n }\n\n async call(method: string, url: URL, headers: Headers = {}, params: Payload = {}, responseType = 'json'): Promise<any> {\n method = method.toUpperCase();\n\n headers = Object.assign({}, this.headers, headers);\n headers.Origin = `appwrite-${Platform.OS}://${this.config.platform}`\n\n let options: RequestInit = {\n method,\n headers,\n };\n\n if (headers['X-Appwrite-Dev-Key'] === undefined) {\n options.credentials = 'include';\n }\n\n if (method === 'GET') {\n for (const [key, value] of Object.entries(Service.flatten(params))) {\n url.searchParams.append(key, value);\n }\n } else {\n switch (headers['content-type']) {\n case 'application/json':\n options.body = JSON.stringify(params);\n break;\n\n case 'multipart/form-data':\n let formData = new FormData();\n\n for (const key in params) {\n if (Array.isArray(params[key])) {\n params[key].forEach((value: any) => {\n formData.append(key + '[]', value);\n })\n } else {\n formData.append(key, params[key]);\n }\n }\n\n options.body = formData;\n delete headers['content-type'];\n break;\n }\n }\n\n try {\n let data = null;\n\n const response = await fetch(url.toString(), options);\n\n const warnings = response.headers.get('x-appwrite-warning');\n if (warnings) {\n warnings.split(';').forEach((warning: string) => console.warn('Warning: ' + warning));\n }\n\n if (response.headers.get('content-type')?.includes('application/json')) {\n data = await response.json();\n } else if (responseType === 'arrayBuffer') {\n data = await response.arrayBuffer();\n } else {\n data = {\n message: await response.text()\n };\n }\n\n if (400 <= response.status) {\n let responseText = '';\n if (response.headers.get('content-type')?.includes('application/json')) {\n responseText = JSON.stringify(data);\n } else {\n responseText = data?.message;\n }\n throw new AppwriteException(data?.message, response.status, data?.type, responseText);\n }\n\n const cookieFallback = response.headers.get('X-Fallback-Cookies');\n\n if (typeof window !== 'undefined' && window.localStorage && cookieFallback) {\n window.console.warn('Appwrite is using localStorage for session management. Increase your security by adding a custom domain as your API endpoint.');\n window.localStorage.setItem('cookieFallback', cookieFallback);\n }\n\n return data;\n } catch (e) {\n if (e instanceof AppwriteException) {\n throw e;\n }\n throw new AppwriteException((<Error>e).message);\n }\n }\n}\n\nexport { Client, AppwriteException };\nexport type { Models, Payload };\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\nimport { AuthenticatorType } from '../enums/authenticator-type';\nimport { AuthenticationFactor } from '../enums/authentication-factor';\nimport { OAuthProvider } from '../enums/o-auth-provider';\n\nexport class Account extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Get the currently logged in user.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n get<Preferences extends Models.Preferences = Models.DefaultPreferences>(): Promise<Models.User<Preferences>> {\n const apiPath = '/account';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Use this endpoint to allow a new user to register a new account in your project. After the user registration completes successfully, you can use the [/account/verfication](https://appwrite.io/docs/references/cloud/client-web/account#createVerification) route to start verifying the user email address. To allow the new user to login to their new account, you need to create a new [account session](https://appwrite.io/docs/references/cloud/client-web/account#createEmailSession).\n *\n * @param {string} params.userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} params.email - User email.\n * @param {string} params.password - New user password. Must be between 8 and 256 chars.\n * @param {string} params.name - User name. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n create<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { userId: string, email: string, password: string, name?: string }): Promise<Models.User<Preferences>>;\n /**\n * Use this endpoint to allow a new user to register a new account in your project. After the user registration completes successfully, you can use the [/account/verfication](https://appwrite.io/docs/references/cloud/client-web/account#createVerification) route to start verifying the user email address. To allow the new user to login to their new account, you need to create a new [account session](https://appwrite.io/docs/references/cloud/client-web/account#createEmailSession).\n *\n * @param {string} userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} email - User email.\n * @param {string} password - New user password. Must be between 8 and 256 chars.\n * @param {string} name - User name. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n create<Preferences extends Models.Preferences = Models.DefaultPreferences>(userId: string, email: string, password: string, name?: string): Promise<Models.User<Preferences>>;\n create<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { userId: string, email: string, password: string, name?: string } | string,\n ...rest: [(string)?, (string)?, (string)?] \n ): Promise<Models.User<Preferences>> {\n let params: { userId: string, email: string, password: string, name?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, email: string, password: string, name?: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n email: rest[0] as string,\n password: rest[1] as string,\n name: rest[2] as string \n };\n }\n\n const userId = params.userId;\n const email = params.email;\n const password = params.password;\n const name = params.name;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof email === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"email\"');\n }\n\n if (typeof password === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"password\"');\n }\n\n const apiPath = '/account';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof email !== 'undefined') {\n payload['email'] = email;\n }\n\n if (typeof password !== 'undefined') {\n payload['password'] = password;\n }\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Update currently logged in user account email address. After changing user address, the user confirmation status will get reset. A new confirmation email is not sent automatically however you can use the send confirmation email endpoint again to send the confirmation email. For security measures, user password is required to complete this request.\n * This endpoint can also be used to convert an anonymous account to a normal one, by passing an email address and a new password.\n * \n *\n * @param {string} params.email - User email.\n * @param {string} params.password - User password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateEmail<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { email: string, password: string }): Promise<Models.User<Preferences>>;\n /**\n * Update currently logged in user account email address. After changing user address, the user confirmation status will get reset. A new confirmation email is not sent automatically however you can use the send confirmation email endpoint again to send the confirmation email. For security measures, user password is required to complete this request.\n * This endpoint can also be used to convert an anonymous account to a normal one, by passing an email address and a new password.\n * \n *\n * @param {string} email - User email.\n * @param {string} password - User password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateEmail<Preferences extends Models.Preferences = Models.DefaultPreferences>(email: string, password: string): Promise<Models.User<Preferences>>;\n updateEmail<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { email: string, password: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.User<Preferences>> {\n let params: { email: string, password: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { email: string, password: string };\n } else {\n params = {\n email: paramsOrFirst as string,\n password: rest[0] as string \n };\n }\n\n const email = params.email;\n const password = params.password;\n\n if (typeof email === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"email\"');\n }\n\n if (typeof password === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"password\"');\n }\n\n const apiPath = '/account/email';\n const payload: Payload = {};\n\n if (typeof email !== 'undefined') {\n payload['email'] = email;\n }\n\n if (typeof password !== 'undefined') {\n payload['password'] = password;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get the list of identities for the currently logged in user.\n *\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: userId, provider, providerUid, providerEmail, providerAccessTokenExpiry\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listIdentities(params?: { queries?: string[] }): Promise<Models.IdentityList>;\n /**\n * Get the list of identities for the currently logged in user.\n *\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: userId, provider, providerUid, providerEmail, providerAccessTokenExpiry\n * @throws {AppwriteException}\n * @returns {Promise<Models.IdentityList>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n listIdentities(queries?: string[]): Promise<Models.IdentityList>;\n listIdentities(\n paramsOrFirst?: { queries?: string[] } | string[] \n ): Promise<Models.IdentityList> {\n let params: { queries?: string[] };\n\n if (!paramsOrFirst || (paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { queries?: string[] };\n } else {\n params = {\n queries: paramsOrFirst as string[] \n };\n }\n\n const queries = params.queries;\n\n const apiPath = '/account/identities';\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Delete an identity by its unique ID.\n *\n * @param {string} params.identityId - Identity ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteIdentity(params: { identityId: string }): Promise<{}>;\n /**\n * Delete an identity by its unique ID.\n *\n * @param {string} identityId - Identity ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteIdentity(identityId: string): Promise<{}>;\n deleteIdentity(\n paramsOrFirst: { identityId: string } | string \n ): Promise<{}> {\n let params: { identityId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { identityId: string };\n } else {\n params = {\n identityId: paramsOrFirst as string \n };\n }\n\n const identityId = params.identityId;\n\n if (typeof identityId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"identityId\"');\n }\n\n const apiPath = '/account/identities/{identityId}'.replace('{identityId}', identityId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to create a JSON Web Token. You can use the resulting JWT to authenticate on behalf of the current user when working with the Appwrite server-side API and SDKs. The JWT secret is valid for 15 minutes from its creation and will be invalid if the user will logout in that time frame.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createJWT(): Promise<Models.Jwt> {\n const apiPath = '/account/jwts';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get the list of latest security activity logs for the currently logged in user. Each log returns user IP address, location and date and time of log.\n *\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Only supported methods are limit and offset\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listLogs(params?: { queries?: string[] }): Promise<Models.LogList>;\n /**\n * Get the list of latest security activity logs for the currently logged in user. Each log returns user IP address, location and date and time of log.\n *\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Only supported methods are limit and offset\n * @throws {AppwriteException}\n * @returns {Promise<Models.LogList>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n listLogs(queries?: string[]): Promise<Models.LogList>;\n listLogs(\n paramsOrFirst?: { queries?: string[] } | string[] \n ): Promise<Models.LogList> {\n let params: { queries?: string[] };\n\n if (!paramsOrFirst || (paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { queries?: string[] };\n } else {\n params = {\n queries: paramsOrFirst as string[] \n };\n }\n\n const queries = params.queries;\n\n const apiPath = '/account/logs';\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Enable or disable MFA on an account.\n *\n * @param {boolean} params.mfa - Enable or disable MFA.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateMFA<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { mfa: boolean }): Promise<Models.User<Preferences>>;\n /**\n * Enable or disable MFA on an account.\n *\n * @param {boolean} mfa - Enable or disable MFA.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMFA<Preferences extends Models.Preferences = Models.DefaultPreferences>(mfa: boolean): Promise<Models.User<Preferences>>;\n updateMFA<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { mfa: boolean } | boolean \n ): Promise<Models.User<Preferences>> {\n let params: { mfa: boolean };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { mfa: boolean };\n } else {\n params = {\n mfa: paramsOrFirst as boolean \n };\n }\n\n const mfa = params.mfa;\n\n if (typeof mfa === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"mfa\"');\n }\n\n const apiPath = '/account/mfa';\n const payload: Payload = {};\n\n if (typeof mfa !== 'undefined') {\n payload['mfa'] = mfa;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Add an authenticator app to be used as an MFA factor. Verify the authenticator using the [verify authenticator](/docs/references/cloud/client-web/account#updateMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} params.type - Type of authenticator. Must be `totp`\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.createMFAAuthenticator` instead.\n */\n createMfaAuthenticator(params: { type: AuthenticatorType }): Promise<Models.MfaType>;\n /**\n * Add an authenticator app to be used as an MFA factor. Verify the authenticator using the [verify authenticator](/docs/references/cloud/client-web/account#updateMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} type - Type of authenticator. Must be `totp`\n * @throws {AppwriteException}\n * @returns {Promise<Models.MfaType>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createMfaAuthenticator(type: AuthenticatorType): Promise<Models.MfaType>;\n createMfaAuthenticator(\n paramsOrFirst: { type: AuthenticatorType } | AuthenticatorType \n ): Promise<Models.MfaType> {\n let params: { type: AuthenticatorType };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'type' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { type: AuthenticatorType };\n } else {\n params = {\n type: paramsOrFirst as AuthenticatorType \n };\n }\n\n const type = params.type;\n\n if (typeof type === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"type\"');\n }\n\n const apiPath = '/account/mfa/authenticators/{type}'.replace('{type}', type);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Add an authenticator app to be used as an MFA factor. Verify the authenticator using the [verify authenticator](/docs/references/cloud/client-web/account#updateMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} params.type - Type of authenticator. Must be `totp`\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createMFAAuthenticator(params: { type: AuthenticatorType }): Promise<Models.MfaType>;\n /**\n * Add an authenticator app to be used as an MFA factor. Verify the authenticator using the [verify authenticator](/docs/references/cloud/client-web/account#updateMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} type - Type of authenticator. Must be `totp`\n * @throws {AppwriteException}\n * @returns {Promise<Models.MfaType>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createMFAAuthenticator(type: AuthenticatorType): Promise<Models.MfaType>;\n createMFAAuthenticator(\n paramsOrFirst: { type: AuthenticatorType } | AuthenticatorType \n ): Promise<Models.MfaType> {\n let params: { type: AuthenticatorType };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'type' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { type: AuthenticatorType };\n } else {\n params = {\n type: paramsOrFirst as AuthenticatorType \n };\n }\n\n const type = params.type;\n\n if (typeof type === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"type\"');\n }\n\n const apiPath = '/account/mfa/authenticators/{type}'.replace('{type}', type);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Verify an authenticator app after adding it using the [add authenticator](/docs/references/cloud/client-web/account#createMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} params.type - Type of authenticator.\n * @param {string} params.otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.updateMFAAuthenticator` instead.\n */\n updateMfaAuthenticator<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { type: AuthenticatorType, otp: string }): Promise<Models.User<Preferences>>;\n /**\n * Verify an authenticator app after adding it using the [add authenticator](/docs/references/cloud/client-web/account#createMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} type - Type of authenticator.\n * @param {string} otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMfaAuthenticator<Preferences extends Models.Preferences = Models.DefaultPreferences>(type: AuthenticatorType, otp: string): Promise<Models.User<Preferences>>;\n updateMfaAuthenticator<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { type: AuthenticatorType, otp: string } | AuthenticatorType,\n ...rest: [(string)?] \n ): Promise<Models.User<Preferences>> {\n let params: { type: AuthenticatorType, otp: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'type' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { type: AuthenticatorType, otp: string };\n } else {\n params = {\n type: paramsOrFirst as AuthenticatorType,\n otp: rest[0] as string \n };\n }\n\n const type = params.type;\n const otp = params.otp;\n\n if (typeof type === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"type\"');\n }\n\n if (typeof otp === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"otp\"');\n }\n\n const apiPath = '/account/mfa/authenticators/{type}'.replace('{type}', type);\n const payload: Payload = {};\n\n if (typeof otp !== 'undefined') {\n payload['otp'] = otp;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Verify an authenticator app after adding it using the [add authenticator](/docs/references/cloud/client-web/account#createMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} params.type - Type of authenticator.\n * @param {string} params.otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateMFAAuthenticator<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { type: AuthenticatorType, otp: string }): Promise<Models.User<Preferences>>;\n /**\n * Verify an authenticator app after adding it using the [add authenticator](/docs/references/cloud/client-web/account#createMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} type - Type of authenticator.\n * @param {string} otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMFAAuthenticator<Preferences extends Models.Preferences = Models.DefaultPreferences>(type: AuthenticatorType, otp: string): Promise<Models.User<Preferences>>;\n updateMFAAuthenticator<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { type: AuthenticatorType, otp: string } | AuthenticatorType,\n ...rest: [(string)?] \n ): Promise<Models.User<Preferences>> {\n let params: { type: AuthenticatorType, otp: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'type' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { type: AuthenticatorType, otp: string };\n } else {\n params = {\n type: paramsOrFirst as AuthenticatorType,\n otp: rest[0] as string \n };\n }\n\n const type = params.type;\n const otp = params.otp;\n\n if (typeof type === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"type\"');\n }\n\n if (typeof otp === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"otp\"');\n }\n\n const apiPath = '/account/mfa/authenticators/{type}'.replace('{type}', type);\n const payload: Payload = {};\n\n if (typeof otp !== 'undefined') {\n payload['otp'] = otp;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete an authenticator for a user by ID.\n *\n * @param {AuthenticatorType} params.type - Type of authenticator.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.deleteMFAAuthenticator` instead.\n */\n deleteMfaAuthenticator(params: { type: AuthenticatorType }): Promise<{}>;\n /**\n * Delete an authenticator for a user by ID.\n *\n * @param {AuthenticatorType} type - Type of authenticator.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteMfaAuthenticator(type: AuthenticatorType): Promise<{}>;\n deleteMfaAuthenticator(\n paramsOrFirst: { type: AuthenticatorType } | AuthenticatorType \n ): Promise<{}> {\n let params: { type: AuthenticatorType };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'type' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { type: AuthenticatorType };\n } else {\n params = {\n type: paramsOrFirst as AuthenticatorType \n };\n }\n\n const type = params.type;\n\n if (typeof type === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"type\"');\n }\n\n const apiPath = '/account/mfa/authenticators/{type}'.replace('{type}', type);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete an authenticator for a user by ID.\n *\n * @param {AuthenticatorType} params.type - Type of authenticator.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteMFAAuthenticator(params: { type: AuthenticatorType }): Promise<{}>;\n /**\n * Delete an authenticator for a user by ID.\n *\n * @param {AuthenticatorType} type - Type of authenticator.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteMFAAuthenticator(type: AuthenticatorType): Promise<{}>;\n deleteMFAAuthenticator(\n paramsOrFirst: { type: AuthenticatorType } | AuthenticatorType \n ): Promise<{}> {\n let params: { type: AuthenticatorType };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'type' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { type: AuthenticatorType };\n } else {\n params = {\n type: paramsOrFirst as AuthenticatorType \n };\n }\n\n const type = params.type;\n\n if (typeof type === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"type\"');\n }\n\n const apiPath = '/account/mfa/authenticators/{type}'.replace('{type}', type);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Begin the process of MFA verification after sign-in. Finish the flow with [updateMfaChallenge](/docs/references/cloud/client-web/account#updateMfaChallenge) method.\n *\n * @param {AuthenticationFactor} params.factor - Factor used for verification. Must be one of following: `email`, `phone`, `totp`, `recoveryCode`.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.createMFAChallenge` instead.\n */\n createMfaChallenge(params: { factor: AuthenticationFactor }): Promise<Models.MfaChallenge>;\n /**\n * Begin the process of MFA verification after sign-in. Finish the flow with [updateMfaChallenge](/docs/references/cloud/client-web/account#updateMfaChallenge) method.\n *\n * @param {AuthenticationFactor} factor - Factor used for verification. Must be one of following: `email`, `phone`, `totp`, `recoveryCode`.\n * @throws {AppwriteException}\n * @returns {Promise<Models.MfaChallenge>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createMfaChallenge(factor: AuthenticationFactor): Promise<Models.MfaChallenge>;\n createMfaChallenge(\n paramsOrFirst: { factor: AuthenticationFactor } | AuthenticationFactor \n ): Promise<Models.MfaChallenge> {\n let params: { factor: AuthenticationFactor };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'factor' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { factor: AuthenticationFactor };\n } else {\n params = {\n factor: paramsOrFirst as AuthenticationFactor \n };\n }\n\n const factor = params.factor;\n\n if (typeof factor === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"factor\"');\n }\n\n const apiPath = '/account/mfa/challenge';\n const payload: Payload = {};\n\n if (typeof factor !== 'undefined') {\n payload['factor'] = factor;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Begin the process of MFA verification after sign-in. Finish the flow with [updateMfaChallenge](/docs/references/cloud/client-web/account#updateMfaChallenge) method.\n *\n * @param {AuthenticationFactor} params.factor - Factor used for verification. Must be one of following: `email`, `phone`, `totp`, `recoveryCode`.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createMFAChallenge(params: { factor: AuthenticationFactor }): Promise<Models.MfaChallenge>;\n /**\n * Begin the process of MFA verification after sign-in. Finish the flow with [updateMfaChallenge](/docs/references/cloud/client-web/account#updateMfaChallenge) method.\n *\n * @param {AuthenticationFactor} factor - Factor used for verification. Must be one of following: `email`, `phone`, `totp`, `recoveryCode`.\n * @throws {AppwriteException}\n * @returns {Promise<Models.MfaChallenge>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createMFAChallenge(factor: AuthenticationFactor): Promise<Models.MfaChallenge>;\n createMFAChallenge(\n paramsOrFirst: { factor: AuthenticationFactor } | AuthenticationFactor \n ): Promise<Models.MfaChallenge> {\n let params: { factor: AuthenticationFactor };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'factor' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { factor: AuthenticationFactor };\n } else {\n params = {\n factor: paramsOrFirst as AuthenticationFactor \n };\n }\n\n const factor = params.factor;\n\n if (typeof factor === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"factor\"');\n }\n\n const apiPath = '/account/mfa/challenge';\n const payload: Payload = {};\n\n if (typeof factor !== 'undefined') {\n payload['factor'] = factor;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Complete the MFA challenge by providing the one-time password. Finish the process of MFA verification by providing the one-time password. To begin the flow, use [createMfaChallenge](/docs/references/cloud/client-web/account#createMfaChallenge) method.\n *\n * @param {string} params.challengeId - ID of the challenge.\n * @param {string} params.otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.updateMFAChallenge` instead.\n */\n updateMfaChallenge(params: { challengeId: string, otp: string }): Promise<Models.Session>;\n /**\n * Complete the MFA challenge by providing the one-time password. Finish the process of MFA verification by providing the one-time password. To begin the flow, use [createMfaChallenge](/docs/references/cloud/client-web/account#createMfaChallenge) method.\n *\n * @param {string} challengeId - ID of the challenge.\n * @param {string} otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMfaChallenge(challengeId: string, otp: string): Promise<Models.Session>;\n updateMfaChallenge(\n paramsOrFirst: { challengeId: string, otp: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Session> {\n let params: { challengeId: string, otp: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { challengeId: string, otp: string };\n } else {\n params = {\n challengeId: paramsOrFirst as string,\n otp: rest[0] as string \n };\n }\n\n const challengeId = params.challengeId;\n const otp = params.otp;\n\n if (typeof challengeId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"challengeId\"');\n }\n\n if (typeof otp === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"otp\"');\n }\n\n const apiPath = '/account/mfa/challenge';\n const payload: Payload = {};\n\n if (typeof challengeId !== 'undefined') {\n payload['challengeId'] = challengeId;\n }\n\n if (typeof otp !== 'undefined') {\n payload['otp'] = otp;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Complete the MFA challenge by providing the one-time password. Finish the process of MFA verification by providing the one-time password. To begin the flow, use [createMfaChallenge](/docs/references/cloud/client-web/account#createMfaChallenge) method.\n *\n * @param {string} params.challengeId - ID of the challenge.\n * @param {string} params.otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateMFAChallenge(params: { challengeId: string, otp: string }): Promise<Models.Session>;\n /**\n * Complete the MFA challenge by providing the one-time password. Finish the process of MFA verification by providing the one-time password. To begin the flow, use [createMfaChallenge](/docs/references/cloud/client-web/account#createMfaChallenge) method.\n *\n * @param {string} challengeId - ID of the challenge.\n * @param {string} otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMFAChallenge(challengeId: string, otp: string): Promise<Models.Session>;\n updateMFAChallenge(\n paramsOrFirst: { challengeId: string, otp: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Session> {\n let params: { challengeId: string, otp: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { challengeId: string, otp: string };\n } else {\n params = {\n challengeId: paramsOrFirst as string,\n otp: rest[0] as string \n };\n }\n\n const challengeId = params.challengeId;\n const otp = params.otp;\n\n if (typeof challengeId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"challengeId\"');\n }\n\n if (typeof otp === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"otp\"');\n }\n\n const apiPath = '/account/mfa/challenge';\n const payload: Payload = {};\n\n if (typeof challengeId !== 'undefined') {\n payload['challengeId'] = challengeId;\n }\n\n if (typeof otp !== 'undefined') {\n payload['otp'] = otp;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * List the factors available on the account to be used as a MFA challange.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.listMFAFactors` instead.\n */\n listMfaFactors(): Promise<Models.MfaFactors> {\n const apiPath = '/account/mfa/factors';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List the factors available on the account to be used as a MFA challange.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listMFAFactors(): Promise<Models.MfaFactors> {\n const apiPath = '/account/mfa/factors';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Get recovery codes that can be used as backup for MFA flow. Before getting codes, they must be generated using [createMfaRecoveryCodes](/docs/references/cloud/client-web/account#createMfaRecoveryCodes) method. An OTP challenge is required to read recovery codes.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.getMFARecoveryCodes` instead.\n */\n getMfaRecoveryCodes(): Promise<Models.MfaRecoveryCodes> {\n const apiPath = '/account/mfa/recovery-codes';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Get recovery codes that can be used as backup for MFA flow. Before getting codes, they must be generated using [createMfaRecoveryCodes](/docs/references/cloud/client-web/account#createMfaRecoveryCodes) method. An OTP challenge is required to read recovery codes.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getMFARecoveryCodes(): Promise<Models.MfaRecoveryCodes> {\n const apiPath = '/account/mfa/recovery-codes';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Generate recovery codes as backup for MFA flow. It's recommended to generate and show then immediately after user successfully adds their authehticator. Recovery codes can be used as a MFA verification type in [createMfaChallenge](/docs/references/cloud/client-web/account#createMfaChallenge) method.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.createMFARecoveryCodes` instead.\n */\n createMfaRecoveryCodes(): Promise<Models.MfaRecoveryCodes> {\n const apiPath = '/account/mfa/recovery-codes';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Generate recovery codes as backup for MFA flow. It's recommended to generate and show then immediately after user successfully adds their authehticator. Recovery codes can be used as a MFA verification type in [createMfaChallenge](/docs/references/cloud/client-web/account#createMfaChallenge) method.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createMFARecoveryCodes(): Promise<Models.MfaRecoveryCodes> {\n const apiPath = '/account/mfa/recovery-codes';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Regenerate recovery codes that can be used as backup for MFA flow. Before regenerating codes, they must be first generated using [createMfaRecoveryCodes](/docs/references/cloud/client-web/account#createMfaRecoveryCodes) method. An OTP challenge is required to regenreate recovery codes.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.updateMFARecoveryCodes` instead.\n */\n updateMfaRecoveryCodes(): Promise<Models.MfaRecoveryCodes> {\n const apiPath = '/account/mfa/recovery-codes';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Regenerate recovery codes that can be used as backup for MFA flow. Before regenerating codes, they must be first generated using [createMfaRecoveryCodes](/docs/references/cloud/client-web/account#createMfaRecoveryCodes) method. An OTP challenge is required to regenreate recovery codes.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateMFARecoveryCodes(): Promise<Models.MfaRecoveryCodes> {\n const apiPath = '/account/mfa/recovery-codes';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Update currently logged in user account name.\n *\n * @param {string} params.name - User name. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateName<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { name: string }): Promise<Models.User<Preferences>>;\n /**\n * Update currently logged in user account name.\n *\n * @param {string} name - User name. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateName<Preferences extends Models.Preferences = Models.DefaultPreferences>(name: string): Promise<Models.User<Preferences>>;\n updateName<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { name: string } | string \n ): Promise<Models.User<Preferences>> {\n let params: { name: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { name: string };\n } else {\n params = {\n name: paramsOrFirst as string \n };\n }\n\n const name = params.name;\n\n if (typeof name === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"name\"');\n }\n\n const apiPath = '/account/name';\n const payload: Payload = {};\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Update currently logged in user password. For validation, user is required to pass in the new password, and the old password. For users created with OAuth, Team Invites and Magic URL, oldPassword is optional.\n *\n * @param {string} params.password - New user password. Must be at least 8 chars.\n * @param {string} params.oldPassword - Current user password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updatePassword<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { password: string, oldPassword?: string }): Promise<Models.User<Preferences>>;\n /**\n * Update currently logged in user password. For validation, user is required to pass in the new password, and the old password. For users created with OAuth, Team Invites and Magic URL, oldPassword is optional.\n *\n * @param {string} password - New user password. Must be at least 8 chars.\n * @param {string} oldPassword - Current user password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updatePassword<Preferences extends Models.Preferences = Models.DefaultPreferences>(password: string, oldPassword?: string): Promise<Models.User<Preferences>>;\n updatePassword<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { password: string, oldPassword?: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.User<Preferences>> {\n let params: { password: string, oldPassword?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { password: string, oldPassword?: string };\n } else {\n params = {\n password: paramsOrFirst as string,\n oldPassword: rest[0] as string \n };\n }\n\n const password = params.password;\n const oldPassword = params.oldPassword;\n\n if (typeof password === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"password\"');\n }\n\n const apiPath = '/account/password';\n const payload: Payload = {};\n\n if (typeof password !== 'undefined') {\n payload['password'] = password;\n }\n\n if (typeof oldPassword !== 'undefined') {\n payload['oldPassword'] = oldPassword;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Update the currently logged in user's phone number. After updating the phone number, the phone verification status will be reset. A confirmation SMS is not sent automatically, however you can use the [POST /account/verification/phone](https://appwrite.io/docs/references/cloud/client-web/account#createPhoneVerification) endpoint to send a confirmation SMS.\n *\n * @param {string} params.phone - Phone number. Format this number with a leading '+' and a country code, e.g., +16175551212.\n * @param {string} params.password - User password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updatePhone<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { phone: string, password: string }): Promise<Models.User<Preferences>>;\n /**\n * Update the currently logged in user's phone number. After updating the phone number, the phone verification status will be reset. A confirmation SMS is not sent automatically, however you can use the [POST /account/verification/phone](https://appwrite.io/docs/references/cloud/client-web/account#createPhoneVerification) endpoint to send a confirmation SMS.\n *\n * @param {string} phone - Phone number. Format this number with a leading '+' and a country code, e.g., +16175551212.\n * @param {string} password - User password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updatePhone<Preferences extends Models.Preferences = Models.DefaultPreferences>(phone: string, password: string): Promise<Models.User<Preferences>>;\n updatePhone<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { phone: string, password: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.User<Preferences>> {\n let params: { phone: string, password: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { phone: string, password: string };\n } else {\n params = {\n phone: paramsOrFirst as string,\n password: rest[0] as string \n };\n }\n\n const phone = params.phone;\n const password = params.password;\n\n if (typeof phone === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"phone\"');\n }\n\n if (typeof password === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"password\"');\n }\n\n const apiPath = '/account/phone';\n const payload: Payload = {};\n\n if (typeof phone !== 'undefined') {\n payload['phone'] = phone;\n }\n\n if (typeof password !== 'undefined') {\n payload['password'] = password;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get the preferences as a key-value object for the currently logged in user.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getPrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(): Promise<Preferences> {\n const apiPath = '/account/prefs';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Update currently logged in user account preferences. The object you pass is stored as is, and replaces any previous value. The maximum allowed prefs size is 64kB and throws error if exceeded.\n *\n * @param {Partial<Preferences>} params.prefs - Prefs key-value JSON object.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updatePrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { prefs: Partial<Preferences> }): Promise<Models.User<Preferences>>;\n /**\n * Update currently logged in user account preferences. The object you pass is stored as is, and replaces any previous value. The maximum allowed prefs size is 64kB and throws error if exceeded.\n *\n * @param {Partial<Preferences>} prefs - Prefs key-value JSON object.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updatePrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(prefs: Partial<Preferences>): Promise<Models.User<Preferences>>;\n updatePrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { prefs: Partial<Preferences> } | Partial<Preferences> \n ): Promise<Models.User<Preferences>> {\n let params: { prefs: Partial<Preferences> };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'prefs' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { prefs: Partial<Preferences> };\n } else {\n params = {\n prefs: paramsOrFirst as Partial<Preferences> \n };\n }\n\n const prefs = params.prefs;\n\n if (typeof prefs === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"prefs\"');\n }\n\n const apiPath = '/account/prefs';\n const payload: Payload = {};\n\n if (typeof prefs !== 'undefined') {\n payload['prefs'] = prefs;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Sends the user an email with a temporary secret key for password reset. When the user clicks the confirmation link he is redirected back to your app password reset URL with the secret key and email address values attached to the URL query string. Use the query string params to submit a request to the [PUT /account/recovery](https://appwrite.io/docs/references/cloud/client-web/account#updateRecovery) endpoint to complete the process. The verification link sent to the user's email address is valid for 1 hour.\n *\n * @param {string} params.email - User email.\n * @param {string} params.url - URL to redirect the user back to your app from the recovery email. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createRecovery(params: { email: string, url: string }): Promise<Models.Token>;\n /**\n * Sends the user an email with a temporary secret key for password reset. When the user clicks the confirmation link he is redirected back to your app password reset URL with the secret key and email address values attached to the URL query string. Use the query string params to submit a request to the [PUT /account/recovery](https://appwrite.io/docs/references/cloud/client-web/account#updateRecovery) endpoint to complete the process. The verification link sent to the user's email address is valid for 1 hour.\n *\n * @param {string} email - User email.\n * @param {string} url - URL to redirect the user back to your app from the recovery email. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createRecovery(email: string, url: string): Promise<Models.Token>;\n createRecovery(\n paramsOrFirst: { email: string, url: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Token> {\n let params: { email: string, url: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { email: string, url: string };\n } else {\n params = {\n email: paramsOrFirst as string,\n url: rest[0] as string \n };\n }\n\n const email = params.email;\n const url = params.url;\n\n if (typeof email === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"email\"');\n }\n\n if (typeof url === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"url\"');\n }\n\n const apiPath = '/account/recovery';\n const payload: Payload = {};\n\n if (typeof email !== 'undefined') {\n payload['email'] = email;\n }\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to complete the user account password reset. Both the **userId** and **secret** arguments will be passed as query parameters to the redirect URL you have provided when sending your request to the [POST /account/recovery](https://appwrite.io/docs/references/cloud/client-web/account#createRecovery) endpoint.\n * \n * Please note that in order to avoid a [Redirect Attack](https://github.com/OWASP/CheatSheetSeries/blob/master/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.md) the only valid redirect URLs are the ones from domains you have set when adding your platforms in the console interface.\n *\n * @param {string} params.userId - User ID.\n * @param {string} params.secret - Valid reset token.\n * @param {string} params.password - New user password. Must be between 8 and 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateRecovery(params: { userId: string, secret: string, password: string }): Promise<Models.Token>;\n /**\n * Use this endpoint to complete the user account password reset. Both the **userId** and **secret** arguments will be passed as query parameters to the redirect URL you have provided when sending your request to the [POST /account/recovery](https://appwrite.io/docs/references/cloud/client-web/account#createRecovery) endpoint.\n * \n * Please note that in order to avoid a [Redirect Attack](https://github.com/OWASP/CheatSheetSeries/blob/master/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.md) the only valid redirect URLs are the ones from domains you have set when adding your platforms in the console interface.\n *\n * @param {string} userId - User ID.\n * @param {string} secret - Valid reset token.\n * @param {string} password - New user password. Must be between 8 and 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateRecovery(userId: string, secret: string, password: string): Promise<Models.Token>;\n updateRecovery(\n paramsOrFirst: { userId: string, secret: string, password: string } | string,\n ...rest: [(string)?, (string)?] \n ): Promise<Models.Token> {\n let params: { userId: string, secret: string, password: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, secret: string, password: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n secret: rest[0] as string,\n password: rest[1] as string \n };\n }\n\n const userId = params.userId;\n const secret = params.secret;\n const password = params.password;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof secret === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"secret\"');\n }\n\n if (typeof password === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"password\"');\n }\n\n const apiPath = '/account/recovery';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof secret !== 'undefined') {\n payload['secret'] = secret;\n }\n\n if (typeof password !== 'undefined') {\n payload['password'] = password;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get the list of active sessions across different devices for the currently logged in user.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listSessions(): Promise<Models.SessionList> {\n const apiPath = '/account/sessions';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Delete all sessions from the user account and remove any sessions cookies from the end client.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteSessions(): Promise<{}> {\n const apiPath = '/account/sessions';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to allow a new user to register an anonymous account in your project. This route will also create a new session for the user. To allow the new user to convert an anonymous account to a normal account, you need to update its [email and password](https://appwrite.io/docs/references/cloud/client-web/account#updateEmail) or create an [OAuth2 session](https://appwrite.io/docs/references/cloud/client-web/account#CreateOAuth2Session).\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createAnonymousSession(): Promise<Models.Session> {\n const apiPath = '/account/sessions/anonymous';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Allow the user to login into their account by providing a valid email and password combination. This route will create a new session for the user.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n *\n * @param {string} params.email - User email.\n * @param {string} params.password - User password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createEmailPasswordSession(params: { email: string, password: string }): Promise<Models.Session>;\n /**\n * Allow the user to login into their account by providing a valid email and password combination. This route will create a new session for the user.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n *\n * @param {string} email - User email.\n * @param {string} password - User password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createEmailPasswordSession(email: string, password: string): Promise<Models.Session>;\n createEmailPasswordSession(\n paramsOrFirst: { email: string, password: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Session> {\n let params: { email: string, password: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { email: string, password: string };\n } else {\n params = {\n email: paramsOrFirst as string,\n password: rest[0] as string \n };\n }\n\n const email = params.email;\n const password = params.password;\n\n if (typeof email === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"email\"');\n }\n\n if (typeof password === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"password\"');\n }\n\n const apiPath = '/account/sessions/email';\n const payload: Payload = {};\n\n if (typeof email !== 'undefined') {\n payload['email'] = email;\n }\n\n if (typeof password !== 'undefined') {\n payload['password'] = password;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to create a session from token. Provide the **userId** and **secret** parameters from the successful response of authentication flows initiated by token creation. For example, magic URL and phone login.\n *\n * @param {string} params.userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} params.secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.6.0. Please use `Account.createSession` instead.\n */\n updateMagicURLSession(params: { userId: string, secret: string }): Promise<Models.Session>;\n /**\n * Use this endpoint to create a session from token. Provide the **userId** and **secret** parameters from the successful response of authentication flows initiated by token creation. For example, magic URL and phone login.\n *\n * @param {string} userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMagicURLSession(userId: string, secret: string): Promise<Models.Session>;\n updateMagicURLSession(\n paramsOrFirst: { userId: string, secret: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Session> {\n let params: { userId: string, secret: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, secret: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n secret: rest[0] as string \n };\n }\n\n const userId = params.userId;\n const secret = params.secret;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof secret === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"secret\"');\n }\n\n const apiPath = '/account/sessions/magic-url';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof secret !== 'undefined') {\n payload['secret'] = secret;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Allow the user to login to their account using the OAuth2 provider of their choice. Each OAuth2 provider should be enabled from the Appwrite console first. Use the success and failure arguments to provide a redirect URL's back to your app when login is completed.\n * \n * If there is already an active session, the new session will be attached to the logged-in account. If there are no active sessions, the server will attempt to look for a user with the same email address as the email received from the OAuth2 provider and attach the new session to the existing user. If no matching user is found - the server will create a new user.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n * \n *\n * @param {OAuthProvider} params.provider - OAuth2 Provider. Currently, supported providers are: amazon, apple, auth0, authentik, autodesk, bitbucket, bitly, box, dailymotion, discord, disqus, dropbox, etsy, facebook, figma, github, gitlab, google, linkedin, microsoft, notion, oidc, okta, paypal, paypalSandbox, podio, salesforce, slack, spotify, stripe, tradeshift, tradeshiftBox, twitch, wordpress, yahoo, yammer, yandex, zoho, zoom.\n * @param {string} params.success - URL to redirect back to your app after a successful login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string} params.failure - URL to redirect back to your app after a failed login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string[]} params.scopes - A list of custom OAuth2 scopes. Check each provider internal docs for a list of supported scopes. Maximum of 100 scopes are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {void|string}\n */\n createOAuth2Session(params: { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] }): void | URL;\n /**\n * Allow the user to login to their account using the OAuth2 provider of their choice. Each OAuth2 provider should be enabled from the Appwrite console first. Use the success and failure arguments to provide a redirect URL's back to your app when login is completed.\n * \n * If there is already an active session, the new session will be attached to the logged-in account. If there are no active sessions, the server will attempt to look for a user with the same email address as the email received from the OAuth2 provider and attach the new session to the existing user. If no matching user is found - the server will create a new user.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n * \n *\n * @param {OAuthProvider} provider - OAuth2 Provider. Currently, supported providers are: amazon, apple, auth0, authentik, autodesk, bitbucket, bitly, box, dailymotion, discord, disqus, dropbox, etsy, facebook, figma, github, gitlab, google, linkedin, microsoft, notion, oidc, okta, paypal, paypalSandbox, podio, salesforce, slack, spotify, stripe, tradeshift, tradeshiftBox, twitch, wordpress, yahoo, yammer, yandex, zoho, zoom.\n * @param {string} success - URL to redirect back to your app after a successful login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string} failure - URL to redirect back to your app after a failed login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string[]} scopes - A list of custom OAuth2 scopes. Check each provider internal docs for a list of supported scopes. Maximum of 100 scopes are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {void | URL}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createOAuth2Session(provider: OAuthProvider, success?: string, failure?: string, scopes?: string[]): void | URL;\n createOAuth2Session(\n paramsOrFirst: { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] } | OAuthProvider,\n ...rest: [(string)?, (string)?, (string[])?] \n ): void | URL {\n let params: { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'provider' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] };\n } else {\n params = {\n provider: paramsOrFirst as OAuthProvider,\n success: rest[0] as string,\n failure: rest[1] as string,\n scopes: rest[2] as string[] \n };\n }\n\n const provider = params.provider;\n const success = params.success;\n const failure = params.failure;\n const scopes = params.scopes;\n\n if (typeof provider === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"provider\"');\n }\n\n const apiPath = '/account/sessions/oauth2/{provider}'.replace('{provider}', provider);\n const payload: Payload = {};\n\n if (typeof success !== 'undefined') {\n payload['success'] = success;\n }\n\n if (typeof failure !== 'undefined') {\n payload['failure'] = failure;\n }\n\n if (typeof scopes !== 'undefined') {\n payload['scopes'] = scopes;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return uri;\n }\n\n /**\n * Use this endpoint to create a session from token. Provide the **userId** and **secret** parameters from the successful response of authentication flows initiated by token creation. For example, magic URL and phone login.\n *\n * @param {string} params.userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} params.secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.6.0. Please use `Account.createSession` instead.\n */\n updatePhoneSession(params: { userId: string, secret: string }): Promise<Models.Session>;\n /**\n * Use this endpoint to create a session from token. Provide the **userId** and **secret** parameters from the successful response of authentication flows initiated by token creation. For example, magic URL and phone login.\n *\n * @param {string} userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updatePhoneSession(userId: string, secret: string): Promise<Models.Session>;\n updatePhoneSession(\n paramsOrFirst: { userId: string, secret: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Session> {\n let params: { userId: string, secret: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, secret: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n secret: rest[0] as string \n };\n }\n\n const userId = params.userId;\n const secret = params.secret;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof secret === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"secret\"');\n }\n\n const apiPath = '/account/sessions/phone';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof secret !== 'undefined') {\n payload['secret'] = secret;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to create a session from token. Provide the **userId** and **secret** parameters from the successful response of authentication flows initiated by token creation. For example, magic URL and phone login.\n *\n * @param {string} params.userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} params.secret - Secret of a token generated by login methods. For example, the `createMagicURLToken` or `createPhoneToken` methods.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createSession(params: { userId: string, secret: string }): Promise<Models.Session>;\n /**\n * Use this endpoint to create a session from token. Provide the **userId** and **secret** parameters from the successful response of authentication flows initiated by token creation. For example, magic URL and phone login.\n *\n * @param {string} userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} secret - Secret of a token generated by login methods. For example, the `createMagicURLToken` or `createPhoneToken` methods.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createSession(userId: string, secret: string): Promise<Models.Session>;\n createSession(\n paramsOrFirst: { userId: string, secret: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Session> {\n let params: { userId: string, secret: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, secret: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n secret: rest[0] as string \n };\n }\n\n const userId = params.userId;\n const secret = params.secret;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof secret === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"secret\"');\n }\n\n const apiPath = '/account/sessions/token';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof secret !== 'undefined') {\n payload['secret'] = secret;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to get a logged in user's session using a Session ID. Inputting 'current' will return the current session being used.\n *\n * @param {string} params.sessionId - Session ID. Use the string 'current' to get the current device session.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getSession(params: { sessionId: string }): Promise<Models.Session>;\n /**\n * Use this endpoint to get a logged in user's session using a Session ID. Inputting 'current' will return the current session being used.\n *\n * @param {string} sessionId - Session ID. Use the string 'current' to get the current device session.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getSession(sessionId: string): Promise<Models.Session>;\n getSession(\n paramsOrFirst: { sessionId: string } | string \n ): Promise<Models.Session> {\n let params: { sessionId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { sessionId: string };\n } else {\n params = {\n sessionId: paramsOrFirst as string \n };\n }\n\n const sessionId = params.sessionId;\n\n if (typeof sessionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"sessionId\"');\n }\n\n const apiPath = '/account/sessions/{sessionId}'.replace('{sessionId}', sessionId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Use this endpoint to extend a session's length. Extending a session is useful when session expiry is short. If the session was created using an OAuth provider, this endpoint refreshes the access token from the provider.\n *\n * @param {string} params.sessionId - Session ID. Use the string 'current' to update the current device session.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateSession(params: { sessionId: string }): Promise<Models.Session>;\n /**\n * Use this endpoint to extend a session's length. Extending a session is useful when session expiry is short. If the session was created using an OAuth provider, this endpoint refreshes the access token from the provider.\n *\n * @param {string} sessionId - Session ID. Use the string 'current' to update the current device session.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateSession(sessionId: string): Promise<Models.Session>;\n updateSession(\n paramsOrFirst: { sessionId: string } | string \n ): Promise<Models.Session> {\n let params: { sessionId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { sessionId: string };\n } else {\n params = {\n sessionId: paramsOrFirst as string \n };\n }\n\n const sessionId = params.sessionId;\n\n if (typeof sessionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"sessionId\"');\n }\n\n const apiPath = '/account/sessions/{sessionId}'.replace('{sessionId}', sessionId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Logout the user. Use 'current' as the session ID to logout on this device, use a session ID to logout on another device. If you're looking to logout the user on all devices, use [Delete Sessions](https://appwrite.io/docs/references/cloud/client-web/account#deleteSessions) instead.\n *\n * @param {string} params.sessionId - Session ID. Use the string 'current' to delete the current device session.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteSession(params: { sessionId: string }): Promise<{}>;\n /**\n * Logout the user. Use 'current' as the session ID to logout on this device, use a session ID to logout on another device. If you're looking to logout the user on all devices, use [Delete Sessions](https://appwrite.io/docs/references/cloud/client-web/account#deleteSessions) instead.\n *\n * @param {string} sessionId - Session ID. Use the string 'current' to delete the current device session.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteSession(sessionId: string): Promise<{}>;\n deleteSession(\n paramsOrFirst: { sessionId: string } | string \n ): Promise<{}> {\n let params: { sessionId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { sessionId: string };\n } else {\n params = {\n sessionId: paramsOrFirst as string \n };\n }\n\n const sessionId = params.sessionId;\n\n if (typeof sessionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"sessionId\"');\n }\n\n const apiPath = '/account/sessions/{sessionId}'.replace('{sessionId}', sessionId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Block the currently logged in user account. Behind the scene, the user record is not deleted but permanently blocked from any access. To completely delete a user, use the Users API instead.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateStatus<Preferences extends Models.Preferences = Models.DefaultPreferences>(): Promise<Models.User<Preferences>> {\n const apiPath = '/account/status';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to register a device for push notifications. Provide a target ID (custom or generated using ID.unique()), a device identifier (usually a device token), and optionally specify which provider should send notifications to this target. The target is automatically linked to the current session and includes device information like brand and model.\n *\n * @param {string} params.targetId - Target ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} params.identifier - The target identifier (token, email, phone etc.)\n * @param {string} params.providerId - Provider ID. Message will be sent to this target from the specified provider ID. If no provider ID is set the first setup provider will be used.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createPushTarget(params: { targetId: string, identifier: string, providerId?: string }): Promise<Models.Target>;\n /**\n * Use this endpoint to register a device for push notifications. Provide a target ID (custom or generated using ID.unique()), a device identifier (usually a device token), and optionally specify which provider should send notifications to this target. The target is automatically linked to the current session and includes device information like brand and model.\n *\n * @param {string} targetId - Target ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} identifier - The target identifier (token, email, phone etc.)\n * @param {string} providerId - Provider ID. Message will be sent to this target from the specified provider ID. If no provider ID is set the first setup provider will be used.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Target>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createPushTarget(targetId: string, identifier: string, providerId?: string): Promise<Models.Target>;\n createPushTarget(\n paramsOrFirst: { targetId: string, identifier: string, providerId?: string } | string,\n ...rest: [(string)?, (string)?] \n ): Promise<Models.Target> {\n let params: { targetId: string, identifier: string, providerId?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { targetId: string, identifier: string, providerId?: string };\n } else {\n params = {\n targetId: paramsOrFirst as string,\n identifier: rest[0] as string,\n providerId: rest[1] as string \n };\n }\n\n const targetId = params.targetId;\n const identifier = params.identifier;\n const providerId = params.providerId;\n\n if (typeof targetId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"targetId\"');\n }\n\n if (typeof identifier === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"identifier\"');\n }\n\n const apiPath = '/account/targets/push';\n const payload: Payload = {};\n\n if (typeof targetId !== 'undefined') {\n payload['targetId'] = targetId;\n }\n\n if (typeof identifier !== 'undefined') {\n payload['identifier'] = identifier;\n }\n\n if (typeof providerId !== 'undefined') {\n payload['providerId'] = providerId;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Update the currently logged in user's push notification target. You can modify the target's identifier (device token) and provider ID (token, email, phone etc.). The target must exist and belong to the current user. If you change the provider ID, notifications will be sent through the new messaging provider instead.\n *\n * @param {string} params.targetId - Target ID.\n * @param {string} params.identifier - The target identifier (token, email, phone etc.)\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updatePushTarget(params: { targetId: string, identifier: string }): Promise<Models.Target>;\n /**\n * Update the currently logged in user's push notification target. You can modify the target's identifier (device token) and provider ID (token, email, phone etc.). The target must exist and belong to the current user. If you change the provider ID, notifications will be sent through the new messaging provider instead.\n *\n * @param {string} targetId - Target ID.\n * @param {string} identifier - The target identifier (token, email, phone etc.)\n * @throws {AppwriteException}\n * @returns {Promise<Models.Target>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updatePushTarget(targetId: string, identifier: string): Promise<Models.Target>;\n updatePushTarget(\n paramsOrFirst: { targetId: string, identifier: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Target> {\n let params: { targetId: string, identifier: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { targetId: string, identifier: string };\n } else {\n params = {\n targetId: paramsOrFirst as string,\n identifier: rest[0] as string \n };\n }\n\n const targetId = params.targetId;\n const identifier = params.identifier;\n\n if (typeof targetId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"targetId\"');\n }\n\n if (typeof identifier === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"identifier\"');\n }\n\n const apiPath = '/account/targets/{targetId}/push'.replace('{targetId}', targetId);\n const payload: Payload = {};\n\n if (typeof identifier !== 'undefined') {\n payload['identifier'] = identifier;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete a push notification target for the currently logged in user. After deletion, the device will no longer receive push notifications. The target must exist and belong to the current user.\n *\n * @param {string} params.targetId - Target ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deletePushTarget(params: { targetId: string }): Promise<{}>;\n /**\n * Delete a push notification target for the currently logged in user. After deletion, the device will no longer receive push notifications. The target must exist and belong to the current user.\n *\n * @param {string} targetId - Target ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deletePushTarget(targetId: string): Promise<{}>;\n deletePushTarget(\n paramsOrFirst: { targetId: string } | string \n ): Promise<{}> {\n let params: { targetId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { targetId: string };\n } else {\n params = {\n targetId: paramsOrFirst as string \n };\n }\n\n const targetId = params.targetId;\n\n if (typeof targetId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"targetId\"');\n }\n\n const apiPath = '/account/targets/{targetId}/push'.replace('{targetId}', targetId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Sends the user an email with a secret key for creating a session. If the email address has never been used, a **new account is created** using the provided `userId`. Otherwise, if the email address is already attached to an account, the **user ID is ignored**. Then, the user will receive an email with the one-time password. Use the returned user ID and secret and submit a request to the [POST /v1/account/sessions/token](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint to complete the login process. The secret sent to the user's email is valid for 15 minutes.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n * \n *\n * @param {string} params.userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars. If the email address has never been used, a new account is created using the provided userId. Otherwise, if the email address is already attached to an account, the user ID is ignored.\n * @param {string} params.email - User email.\n * @param {boolean} params.phrase - Toggle for security phrase. If enabled, email will be send with a randomly generated phrase and the phrase will also be included in the response. Confirming phrases match increases the security of your authentication flow.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createEmailToken(params: { userId: string, email: string, phrase?: boolean }): Promise<Models.Token>;\n /**\n * Sends the user an email with a secret key for creating a session. If the email address has never been used, a **new account is created** using the provided `userId`. Otherwise, if the email address is already attached to an account, the **user ID is ignored**. Then, the user will receive an email with the one-time password. Use the returned user ID and secret and submit a request to the [POST /v1/account/sessions/token](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint to complete the login process. The secret sent to the user's email is valid for 15 minutes.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n * \n *\n * @param {string} userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars. If the email address has never been used, a new account is created using the provided userId. Otherwise, if the email address is already attached to an account, the user ID is ignored.\n * @param {string} email - User email.\n * @param {boolean} phrase - Toggle for security phrase. If enabled, email will be send with a randomly generated phrase and the phrase will also be included in the response. Confirming phrases match increases the security of your authentication flow.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createEmailToken(userId: string, email: string, phrase?: boolean): Promise<Models.Token>;\n createEmailToken(\n paramsOrFirst: { userId: string, email: string, phrase?: boolean } | string,\n ...rest: [(string)?, (boolean)?] \n ): Promise<Models.Token> {\n let params: { userId: string, email: string, phrase?: boolean };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, email: string, phrase?: boolean };\n } else {\n params = {\n userId: paramsOrFirst as string,\n email: rest[0] as string,\n phrase: rest[1] as boolean \n };\n }\n\n const userId = params.userId;\n const email = params.email;\n const phrase = params.phrase;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof email === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"email\"');\n }\n\n const apiPath = '/account/tokens/email';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof email !== 'undefined') {\n payload['email'] = email;\n }\n\n if (typeof phrase !== 'undefined') {\n payload['phrase'] = phrase;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Sends the user an email with a secret key for creating a session. If the provided user ID has not been registered, a new user will be created. When the user clicks the link in the email, the user is redirected back to the URL you provided with the secret key and userId values attached to the URL query string. Use the query string parameters to submit a request to the [POST /v1/account/sessions/token](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint to complete the login process. The link sent to the user's email address is valid for 1 hour.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n * \n *\n * @param {string} params.userId - Unique Id. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars. If the email address has never been used, a new account is created using the provided userId. Otherwise, if the email address is already attached to an account, the user ID is ignored.\n * @param {string} params.email - User email.\n * @param {string} params.url - URL to redirect the user back to your app from the magic URL login. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {boolean} params.phrase - Toggle for security phrase. If enabled, email will be send with a randomly generated phrase and the phrase will also be included in the response. Confirming phrases match increases the security of your authentication flow.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createMagicURLToken(params: { userId: string, email: string, url?: string, phrase?: boolean }): Promise<Models.Token>;\n /**\n * Sends the user an email with a secret key for creating a session. If the provided user ID has not been registered, a new user will be created. When the user clicks the link in the email, the user is redirected back to the URL you provided with the secret key and userId values attached to the URL query string. Use the query string parameters to submit a request to the [POST /v1/account/sessions/token](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint to complete the login process. The link sent to the user's email address is valid for 1 hour.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n * \n *\n * @param {string} userId - Unique Id. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars. If the email address has never been used, a new account is created using the provided userId. Otherwise, if the email address is already attached to an account, the user ID is ignored.\n * @param {string} email - User email.\n * @param {string} url - URL to redirect the user back to your app from the magic URL login. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {boolean} phrase - Toggle for security phrase. If enabled, email will be send with a randomly generated phrase and the phrase will also be included in the response. Confirming phrases match increases the security of your authentication flow.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createMagicURLToken(userId: string, email: string, url?: string, phrase?: boolean): Promise<Models.Token>;\n createMagicURLToken(\n paramsOrFirst: { userId: string, email: string, url?: string, phrase?: boolean } | string,\n ...rest: [(string)?, (string)?, (boolean)?] \n ): Promise<Models.Token> {\n let params: { userId: string, email: string, url?: string, phrase?: boolean };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, email: string, url?: string, phrase?: boolean };\n } else {\n params = {\n userId: paramsOrFirst as string,\n email: rest[0] as string,\n url: rest[1] as string,\n phrase: rest[2] as boolean \n };\n }\n\n const userId = params.userId;\n const email = params.email;\n const url = params.url;\n const phrase = params.phrase;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof email === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"email\"');\n }\n\n const apiPath = '/account/tokens/magic-url';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof email !== 'undefined') {\n payload['email'] = email;\n }\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n if (typeof phrase !== 'undefined') {\n payload['phrase'] = phrase;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Allow the user to login to their account using the OAuth2 provider of their choice. Each OAuth2 provider should be enabled from the Appwrite console first. Use the success and failure arguments to provide a redirect URL's back to your app when login is completed. \n * \n * If authentication succeeds, `userId` and `secret` of a token will be appended to the success URL as query parameters. These can be used to create a new session using the [Create session](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n *\n * @param {OAuthProvider} params.provider - OAuth2 Provider. Currently, supported providers are: amazon, apple, auth0, authentik, autodesk, bitbucket, bitly, box, dailymotion, discord, disqus, dropbox, etsy, facebook, figma, github, gitlab, google, linkedin, microsoft, notion, oidc, okta, paypal, paypalSandbox, podio, salesforce, slack, spotify, stripe, tradeshift, tradeshiftBox, twitch, wordpress, yahoo, yammer, yandex, zoho, zoom.\n * @param {string} params.success - URL to redirect back to your app after a successful login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string} params.failure - URL to redirect back to your app after a failed login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string[]} params.scopes - A list of custom OAuth2 scopes. Check each provider internal docs for a list of supported scopes. Maximum of 100 scopes are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {void|string}\n */\n createOAuth2Token(params: { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] }): void | URL;\n /**\n * Allow the user to login to their account using the OAuth2 provider of their choice. Each OAuth2 provider should be enabled from the Appwrite console first. Use the success and failure arguments to provide a redirect URL's back to your app when login is completed. \n * \n * If authentication succeeds, `userId` and `secret` of a token will be appended to the success URL as query parameters. These can be used to create a new session using the [Create session](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n *\n * @param {OAuthProvider} provider - OAuth2 Provider. Currently, supported providers are: amazon, apple, auth0, authentik, autodesk, bitbucket, bitly, box, dailymotion, discord, disqus, dropbox, etsy, facebook, figma, github, gitlab, google, linkedin, microsoft, notion, oidc, okta, paypal, paypalSandbox, podio, salesforce, slack, spotify, stripe, tradeshift, tradeshiftBox, twitch, wordpress, yahoo, yammer, yandex, zoho, zoom.\n * @param {string} success - URL to redirect back to your app after a successful login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string} failure - URL to redirect back to your app after a failed login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string[]} scopes - A list of custom OAuth2 scopes. Check each provider internal docs for a list of supported scopes. Maximum of 100 scopes are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {void | URL}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createOAuth2Token(provider: OAuthProvider, success?: string, failure?: string, scopes?: string[]): void | URL;\n createOAuth2Token(\n paramsOrFirst: { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] } | OAuthProvider,\n ...rest: [(string)?, (string)?, (string[])?] \n ): void | URL {\n let params: { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'provider' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] };\n } else {\n params = {\n provider: paramsOrFirst as OAuthProvider,\n success: rest[0] as string,\n failure: rest[1] as string,\n scopes: rest[2] as string[] \n };\n }\n\n const provider = params.provider;\n const success = params.success;\n const failure = params.failure;\n const scopes = params.scopes;\n\n if (typeof provider === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"provider\"');\n }\n\n const apiPath = '/account/tokens/oauth2/{provider}'.replace('{provider}', provider);\n const payload: Payload = {};\n\n if (typeof success !== 'undefined') {\n payload['success'] = success;\n }\n\n if (typeof failure !== 'undefined') {\n payload['failure'] = failure;\n }\n\n if (typeof scopes !== 'undefined') {\n payload['scopes'] = scopes;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return uri;\n }\n\n /**\n * Sends the user an SMS with a secret key for creating a session. If the provided user ID has not be registered, a new user will be created. Use the returned user ID and secret and submit a request to the [POST /v1/account/sessions/token](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint to complete the login process. The secret sent to the user's phone is valid for 15 minutes.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n *\n * @param {string} params.userId - Unique Id. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars. If the phone number has never been used, a new account is created using the provided userId. Otherwise, if the phone number is already attached to an account, the user ID is ignored.\n * @param {string} params.phone - Phone number. Format this number with a leading '+' and a country code, e.g., +16175551212.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createPhoneToken(params: { userId: string, phone: string }): Promise<Models.Token>;\n /**\n * Sends the user an SMS with a secret key for creating a session. If the provided user ID has not be registered, a new user will be created. Use the returned user ID and secret and submit a request to the [POST /v1/account/sessions/token](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint to complete the login process. The secret sent to the user's phone is valid for 15 minutes.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n *\n * @param {string} userId - Unique Id. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars. If the phone number has never been used, a new account is created using the provided userId. Otherwise, if the phone number is already attached to an account, the user ID is ignored.\n * @param {string} phone - Phone number. Format this number with a leading '+' and a country code, e.g., +16175551212.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createPhoneToken(userId: string, phone: string): Promise<Models.Token>;\n createPhoneToken(\n paramsOrFirst: { userId: string, phone: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Token> {\n let params: { userId: string, phone: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, phone: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n phone: rest[0] as string \n };\n }\n\n const userId = params.userId;\n const phone = params.phone;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof phone === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"phone\"');\n }\n\n const apiPath = '/account/tokens/phone';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof phone !== 'undefined') {\n payload['phone'] = phone;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to send a verification message to your user email address to confirm they are the valid owners of that address. Both the **userId** and **secret** arguments will be passed as query parameters to the URL you have provided to be attached to the verification email. The provided URL should redirect the user back to your app and allow you to complete the verification process by verifying both the **userId** and **secret** parameters. Learn more about how to [complete the verification process](https://appwrite.io/docs/references/cloud/client-web/account#updateVerification). The verification link sent to the user's email address is valid for 7 days.\n * \n * Please note that in order to avoid a [Redirect Attack](https://github.com/OWASP/CheatSheetSeries/blob/master/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.md), the only valid redirect URLs are the ones from domains you have set when adding your platforms in the console interface.\n * \n *\n * @param {string} params.url - URL to redirect the user back to your app from the verification email. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createVerification(params: { url: string }): Promise<Models.Token>;\n /**\n * Use this endpoint to send a verification message to your user email address to confirm they are the valid owners of that address. Both the **userId** and **secret** arguments will be passed as query parameters to the URL you have provided to be attached to the verification email. The provided URL should redirect the user back to your app and allow you to complete the verification process by verifying both the **userId** and **secret** parameters. Learn more about how to [complete the verification process](https://appwrite.io/docs/references/cloud/client-web/account#updateVerification). The verification link sent to the user's email address is valid for 7 days.\n * \n * Please note that in order to avoid a [Redirect Attack](https://github.com/OWASP/CheatSheetSeries/blob/master/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.md), the only valid redirect URLs are the ones from domains you have set when adding your platforms in the console interface.\n * \n *\n * @param {string} url - URL to redirect the user back to your app from the verification email. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createVerification(url: string): Promise<Models.Token>;\n createVerification(\n paramsOrFirst: { url: string } | string \n ): Promise<Models.Token> {\n let params: { url: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { url: string };\n } else {\n params = {\n url: paramsOrFirst as string \n };\n }\n\n const url = params.url;\n\n if (typeof url === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"url\"');\n }\n\n const apiPath = '/account/verification';\n const payload: Payload = {};\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to complete the user email verification process. Use both the **userId** and **secret** parameters that were attached to your app URL to verify the user email ownership. If confirmed this route will return a 200 status code.\n *\n * @param {string} params.userId - User ID.\n * @param {string} params.secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateVerification(params: { userId: string, secret: string }): Promise<Models.Token>;\n /**\n * Use this endpoint to complete the user email verification process. Use both the **userId** and **secret** parameters that were attached to your app URL to verify the user email ownership. If confirmed this route will return a 200 status code.\n *\n * @param {string} userId - User ID.\n * @param {string} secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateVerification(userId: string, secret: string): Promise<Models.Token>;\n updateVerification(\n paramsOrFirst: { userId: string, secret: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Token> {\n let params: { userId: string, secret: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, secret: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n secret: rest[0] as string \n };\n }\n\n const userId = params.userId;\n const secret = params.secret;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof secret === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"secret\"');\n }\n\n const apiPath = '/account/verification';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof secret !== 'undefined') {\n payload['secret'] = secret;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to send a verification SMS to the currently logged in user. This endpoint is meant for use after updating a user's phone number using the [accountUpdatePhone](https://appwrite.io/docs/references/cloud/client-web/account#updatePhone) endpoint. Learn more about how to [complete the verification process](https://appwrite.io/docs/references/cloud/client-web/account#updatePhoneVerification). The verification code sent to the user's phone number is valid for 15 minutes.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createPhoneVerification(): Promise<Models.Token> {\n const apiPath = '/account/verification/phone';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to complete the user phone verification process. Use the **userId** and **secret** that were sent to your user's phone number to verify the user email ownership. If confirmed this route will return a 200 status code.\n *\n * @param {string} params.userId - User ID.\n * @param {string} params.secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updatePhoneVerification(params: { userId: string, secret: string }): Promise<Models.Token>;\n /**\n * Use this endpoint to complete the user phone verification process. Use the **userId** and **secret** that were sent to your user's phone number to verify the user email ownership. If confirmed this route will return a 200 status code.\n *\n * @param {string} userId - User ID.\n * @param {string} secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updatePhoneVerification(userId: string, secret: string): Promise<Models.Token>;\n updatePhoneVerification(\n paramsOrFirst: { userId: string, secret: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Token> {\n let params: { userId: string, secret: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, secret: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n secret: rest[0] as string \n };\n }\n\n const userId = params.userId;\n const secret = params.secret;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof secret === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"secret\"');\n }\n\n const apiPath = '/account/verification/phone';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof secret !== 'undefined') {\n payload['secret'] = secret;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\nimport { Browser } from '../enums/browser';\nimport { CreditCard } from '../enums/credit-card';\nimport { Flag } from '../enums/flag';\n\nexport class Avatars extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * You can use this endpoint to show different browser icons to your users. The code argument receives the browser code as it appears in your user [GET /account/sessions](https://appwrite.io/docs/references/cloud/client-web/account#getSessions) endpoint. Use width, height and quality arguments to change the output settings.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n *\n * @param {Browser} params.code - Browser Code.\n * @param {number} params.width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} params.height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} params.quality - Image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getBrowser(params: { code: Browser, width?: number, height?: number, quality?: number }): Promise<ArrayBuffer>;\n /**\n * You can use this endpoint to show different browser icons to your users. The code argument receives the browser code as it appears in your user [GET /account/sessions](https://appwrite.io/docs/references/cloud/client-web/account#getSessions) endpoint. Use width, height and quality arguments to change the output settings.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n *\n * @param {Browser} code - Browser Code.\n * @param {number} width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} quality - Image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getBrowser(code: Browser, width?: number, height?: number, quality?: number): Promise<ArrayBuffer>;\n getBrowser(\n paramsOrFirst: { code: Browser, width?: number, height?: number, quality?: number } | Browser,\n ...rest: [(number)?, (number)?, (number)?] \n ): Promise<ArrayBuffer> {\n let params: { code: Browser, width?: number, height?: number, quality?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'code' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { code: Browser, width?: number, height?: number, quality?: number };\n } else {\n params = {\n code: paramsOrFirst as Browser,\n width: rest[0] as number,\n height: rest[1] as number,\n quality: rest[2] as number \n };\n }\n\n const code = params.code;\n const width = params.width;\n const height = params.height;\n const quality = params.quality;\n\n if (typeof code === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"code\"');\n }\n\n const apiPath = '/avatars/browsers/{code}'.replace('{code}', code);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * The credit card endpoint will return you the icon of the credit card provider you need. Use width, height and quality arguments to change the output settings.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n * \n *\n * @param {CreditCard} params.code - Credit Card Code. Possible values: amex, argencard, cabal, cencosud, diners, discover, elo, hipercard, jcb, mastercard, naranja, targeta-shopping, unionpay, visa, mir, maestro, rupay.\n * @param {number} params.width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} params.height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} params.quality - Image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getCreditCard(params: { code: CreditCard, width?: number, height?: number, quality?: number }): Promise<ArrayBuffer>;\n /**\n * The credit card endpoint will return you the icon of the credit card provider you need. Use width, height and quality arguments to change the output settings.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n * \n *\n * @param {CreditCard} code - Credit Card Code. Possible values: amex, argencard, cabal, cencosud, diners, discover, elo, hipercard, jcb, mastercard, naranja, targeta-shopping, unionpay, visa, mir, maestro, rupay.\n * @param {number} width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} quality - Image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getCreditCard(code: CreditCard, width?: number, height?: number, quality?: number): Promise<ArrayBuffer>;\n getCreditCard(\n paramsOrFirst: { code: CreditCard, width?: number, height?: number, quality?: number } | CreditCard,\n ...rest: [(number)?, (number)?, (number)?] \n ): Promise<ArrayBuffer> {\n let params: { code: CreditCard, width?: number, height?: number, quality?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'code' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { code: CreditCard, width?: number, height?: number, quality?: number };\n } else {\n params = {\n code: paramsOrFirst as CreditCard,\n width: rest[0] as number,\n height: rest[1] as number,\n quality: rest[2] as number \n };\n }\n\n const code = params.code;\n const width = params.width;\n const height = params.height;\n const quality = params.quality;\n\n if (typeof code === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"code\"');\n }\n\n const apiPath = '/avatars/credit-cards/{code}'.replace('{code}', code);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * Use this endpoint to fetch the favorite icon (AKA favicon) of any remote website URL.\n * \n * This endpoint does not follow HTTP redirects.\n *\n * @param {string} params.url - Website URL which you want to fetch the favicon from.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getFavicon(params: { url: string }): Promise<ArrayBuffer>;\n /**\n * Use this endpoint to fetch the favorite icon (AKA favicon) of any remote website URL.\n * \n * This endpoint does not follow HTTP redirects.\n *\n * @param {string} url - Website URL which you want to fetch the favicon from.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getFavicon(url: string): Promise<ArrayBuffer>;\n getFavicon(\n paramsOrFirst: { url: string } | string \n ): Promise<ArrayBuffer> {\n let params: { url: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { url: string };\n } else {\n params = {\n url: paramsOrFirst as string \n };\n }\n\n const url = params.url;\n\n if (typeof url === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"url\"');\n }\n\n const apiPath = '/avatars/favicon';\n const payload: Payload = {};\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * You can use this endpoint to show different country flags icons to your users. The code argument receives the 2 letter country code. Use width, height and quality arguments to change the output settings. Country codes follow the [ISO 3166-1](https://en.wikipedia.org/wiki/ISO_3166-1) standard.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n * \n *\n * @param {Flag} params.code - Country Code. ISO Alpha-2 country code format.\n * @param {number} params.width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} params.height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} params.quality - Image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getFlag(params: { code: Flag, width?: number, height?: number, quality?: number }): Promise<ArrayBuffer>;\n /**\n * You can use this endpoint to show different country flags icons to your users. The code argument receives the 2 letter country code. Use width, height and quality arguments to change the output settings. Country codes follow the [ISO 3166-1](https://en.wikipedia.org/wiki/ISO_3166-1) standard.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n * \n *\n * @param {Flag} code - Country Code. ISO Alpha-2 country code format.\n * @param {number} width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} quality - Image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getFlag(code: Flag, width?: number, height?: number, quality?: number): Promise<ArrayBuffer>;\n getFlag(\n paramsOrFirst: { code: Flag, width?: number, height?: number, quality?: number } | Flag,\n ...rest: [(number)?, (number)?, (number)?] \n ): Promise<ArrayBuffer> {\n let params: { code: Flag, width?: number, height?: number, quality?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'code' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { code: Flag, width?: number, height?: number, quality?: number };\n } else {\n params = {\n code: paramsOrFirst as Flag,\n width: rest[0] as number,\n height: rest[1] as number,\n quality: rest[2] as number \n };\n }\n\n const code = params.code;\n const width = params.width;\n const height = params.height;\n const quality = params.quality;\n\n if (typeof code === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"code\"');\n }\n\n const apiPath = '/avatars/flags/{code}'.replace('{code}', code);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * Use this endpoint to fetch a remote image URL and crop it to any image size you want. This endpoint is very useful if you need to crop and display remote images in your app or in case you want to make sure a 3rd party image is properly served using a TLS protocol.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 400x400px.\n * \n * This endpoint does not follow HTTP redirects.\n *\n * @param {string} params.url - Image URL which you want to crop.\n * @param {number} params.width - Resize preview image width, Pass an integer between 0 to 2000. Defaults to 400.\n * @param {number} params.height - Resize preview image height, Pass an integer between 0 to 2000. Defaults to 400.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getImage(params: { url: string, width?: number, height?: number }): Promise<ArrayBuffer>;\n /**\n * Use this endpoint to fetch a remote image URL and crop it to any image size you want. This endpoint is very useful if you need to crop and display remote images in your app or in case you want to make sure a 3rd party image is properly served using a TLS protocol.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 400x400px.\n * \n * This endpoint does not follow HTTP redirects.\n *\n * @param {string} url - Image URL which you want to crop.\n * @param {number} width - Resize preview image width, Pass an integer between 0 to 2000. Defaults to 400.\n * @param {number} height - Resize preview image height, Pass an integer between 0 to 2000. Defaults to 400.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getImage(url: string, width?: number, height?: number): Promise<ArrayBuffer>;\n getImage(\n paramsOrFirst: { url: string, width?: number, height?: number } | string,\n ...rest: [(number)?, (number)?] \n ): Promise<ArrayBuffer> {\n let params: { url: string, width?: number, height?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { url: string, width?: number, height?: number };\n } else {\n params = {\n url: paramsOrFirst as string,\n width: rest[0] as number,\n height: rest[1] as number \n };\n }\n\n const url = params.url;\n const width = params.width;\n const height = params.height;\n\n if (typeof url === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"url\"');\n }\n\n const apiPath = '/avatars/image';\n const payload: Payload = {};\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * Use this endpoint to show your user initials avatar icon on your website or app. By default, this route will try to print your logged-in user name or email initials. You can also overwrite the user name if you pass the 'name' parameter. If no name is given and no user is logged, an empty avatar will be returned.\n * \n * You can use the color and background params to change the avatar colors. By default, a random theme will be selected. The random theme will persist for the user's initials when reloading the same theme will always return for the same initials.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n * \n *\n * @param {string} params.name - Full Name. When empty, current user name or email will be used. Max length: 128 chars.\n * @param {number} params.width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} params.height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {string} params.background - Changes background color. By default a random color will be picked and stay will persistent to the given name.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getInitials(params?: { name?: string, width?: number, height?: number, background?: string }): Promise<ArrayBuffer>;\n /**\n * Use this endpoint to show your user initials avatar icon on your website or app. By default, this route will try to print your logged-in user name or email initials. You can also overwrite the user name if you pass the 'name' parameter. If no name is given and no user is logged, an empty avatar will be returned.\n * \n * You can use the color and background params to change the avatar colors. By default, a random theme will be selected. The random theme will persist for the user's initials when reloading the same theme will always return for the same initials.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n * \n *\n * @param {string} name - Full Name. When empty, current user name or email will be used. Max length: 128 chars.\n * @param {number} width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {string} background - Changes background color. By default a random color will be picked and stay will persistent to the given name.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getInitials(name?: string, width?: number, height?: number, background?: string): Promise<ArrayBuffer>;\n getInitials(\n paramsOrFirst?: { name?: string, width?: number, height?: number, background?: string } | string,\n ...rest: [(number)?, (number)?, (string)?] \n ): Promise<ArrayBuffer> {\n let params: { name?: string, width?: number, height?: number, background?: string };\n\n if (!paramsOrFirst || (paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { name?: string, width?: number, height?: number, background?: string };\n } else {\n params = {\n name: paramsOrFirst as string,\n width: rest[0] as number,\n height: rest[1] as number,\n background: rest[2] as string \n };\n }\n\n const name = params.name;\n const width = params.width;\n const height = params.height;\n const background = params.background;\n\n const apiPath = '/avatars/initials';\n const payload: Payload = {};\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof background !== 'undefined') {\n payload['background'] = background;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * Converts a given plain text to a QR code image. You can use the query parameters to change the size and style of the resulting image.\n * \n *\n * @param {string} params.text - Plain text to be converted to QR code image.\n * @param {number} params.size - QR code size. Pass an integer between 1 to 1000. Defaults to 400.\n * @param {number} params.margin - Margin from edge. Pass an integer between 0 to 10. Defaults to 1.\n * @param {boolean} params.download - Return resulting image with 'Content-Disposition: attachment ' headers for the browser to start downloading it. Pass 0 for no header, or 1 for otherwise. Default value is set to 0.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getQR(params: { text: string, size?: number, margin?: number, download?: boolean }): Promise<ArrayBuffer>;\n /**\n * Converts a given plain text to a QR code image. You can use the query parameters to change the size and style of the resulting image.\n * \n *\n * @param {string} text - Plain text to be converted to QR code image.\n * @param {number} size - QR code size. Pass an integer between 1 to 1000. Defaults to 400.\n * @param {number} margin - Margin from edge. Pass an integer between 0 to 10. Defaults to 1.\n * @param {boolean} download - Return resulting image with 'Content-Disposition: attachment ' headers for the browser to start downloading it. Pass 0 for no header, or 1 for otherwise. Default value is set to 0.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getQR(text: string, size?: number, margin?: number, download?: boolean): Promise<ArrayBuffer>;\n getQR(\n paramsOrFirst: { text: string, size?: number, margin?: number, download?: boolean } | string,\n ...rest: [(number)?, (number)?, (boolean)?] \n ): Promise<ArrayBuffer> {\n let params: { text: string, size?: number, margin?: number, download?: boolean };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { text: string, size?: number, margin?: number, download?: boolean };\n } else {\n params = {\n text: paramsOrFirst as string,\n size: rest[0] as number,\n margin: rest[1] as number,\n download: rest[2] as boolean \n };\n }\n\n const text = params.text;\n const size = params.size;\n const margin = params.margin;\n const download = params.download;\n\n if (typeof text === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"text\"');\n }\n\n const apiPath = '/avatars/qr';\n const payload: Payload = {};\n\n if (typeof text !== 'undefined') {\n payload['text'] = text;\n }\n\n if (typeof size !== 'undefined') {\n payload['size'] = size;\n }\n\n if (typeof margin !== 'undefined') {\n payload['margin'] = margin;\n }\n\n if (typeof download !== 'undefined') {\n payload['download'] = download;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * You can use this endpoint to show different browser icons to your users.\n * The code argument receives the browser code as it appears in your user [GET\n * /account/sessions](https://appwrite.io/docs/references/cloud/client-web/account#getSessions)\n * endpoint. Use width, height and quality arguments to change the output\n * settings.\n * \n * When one dimension is specified and the other is 0, the image is scaled\n * with preserved aspect ratio. If both dimensions are 0, the API provides an\n * image at source quality. If dimensions are not specified, the default size\n * of image returned is 100x100px.\n *\n * @param {Browser} code\n * @param {number} width\n * @param {number} height\n * @param {number} quality\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getBrowserURL(code: Browser, width?: number, height?: number, quality?: number): URL {\n const apiPath = '/avatars/browsers/{code}'.replace('{code}', code);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * The credit card endpoint will return you the icon of the credit card\n * provider you need. Use width, height and quality arguments to change the\n * output settings.\n * \n * When one dimension is specified and the other is 0, the image is scaled\n * with preserved aspect ratio. If both dimensions are 0, the API provides an\n * image at source quality. If dimensions are not specified, the default size\n * of image returned is 100x100px.\n * \n *\n * @param {CreditCard} code\n * @param {number} width\n * @param {number} height\n * @param {number} quality\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getCreditCardURL(code: CreditCard, width?: number, height?: number, quality?: number): URL {\n const apiPath = '/avatars/credit-cards/{code}'.replace('{code}', code);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * Use this endpoint to fetch the favorite icon (AKA favicon) of any remote\n * website URL.\n * \n * This endpoint does not follow HTTP redirects.\n *\n * @param {string} url\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getFaviconURL(url: string): URL {\n const apiPath = '/avatars/favicon';\n const payload: Payload = {};\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * You can use this endpoint to show different country flags icons to your\n * users. The code argument receives the 2 letter country code. Use width,\n * height and quality arguments to change the output settings. Country codes\n * follow the [ISO 3166-1](https://en.wikipedia.org/wiki/ISO_3166-1) standard.\n * \n * When one dimension is specified and the other is 0, the image is scaled\n * with preserved aspect ratio. If both dimensions are 0, the API provides an\n * image at source quality. If dimensions are not specified, the default size\n * of image returned is 100x100px.\n * \n *\n * @param {Flag} code\n * @param {number} width\n * @param {number} height\n * @param {number} quality\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getFlagURL(code: Flag, width?: number, height?: number, quality?: number): URL {\n const apiPath = '/avatars/flags/{code}'.replace('{code}', code);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * Use this endpoint to fetch a remote image URL and crop it to any image size\n * you want. This endpoint is very useful if you need to crop and display\n * remote images in your app or in case you want to make sure a 3rd party\n * image is properly served using a TLS protocol.\n * \n * When one dimension is specified and the other is 0, the image is scaled\n * with preserved aspect ratio. If both dimensions are 0, the API provides an\n * image at source quality. If dimensions are not specified, the default size\n * of image returned is 400x400px.\n * \n * This endpoint does not follow HTTP redirects.\n *\n * @param {string} url\n * @param {number} width\n * @param {number} height\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getImageURL(url: string, width?: number, height?: number): URL {\n const apiPath = '/avatars/image';\n const payload: Payload = {};\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * Use this endpoint to show your user initials avatar icon on your website or\n * app. By default, this route will try to print your logged-in user name or\n * email initials. You can also overwrite the user name if you pass the 'name'\n * parameter. If no name is given and no user is logged, an empty avatar will\n * be returned.\n * \n * You can use the color and background params to change the avatar colors. By\n * default, a random theme will be selected. The random theme will persist for\n * the user's initials when reloading the same theme will always return for\n * the same initials.\n * \n * When one dimension is specified and the other is 0, the image is scaled\n * with preserved aspect ratio. If both dimensions are 0, the API provides an\n * image at source quality. If dimensions are not specified, the default size\n * of image returned is 100x100px.\n * \n *\n * @param {string} name\n * @param {number} width\n * @param {number} height\n * @param {string} background\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getInitialsURL(name?: string, width?: number, height?: number, background?: string): URL {\n const apiPath = '/avatars/initials';\n const payload: Payload = {};\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof background !== 'undefined') {\n payload['background'] = background;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * Converts a given plain text to a QR code image. You can use the query\n * parameters to change the size and style of the resulting image.\n * \n *\n * @param {string} text\n * @param {number} size\n * @param {number} margin\n * @param {boolean} download\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getQRURL(text: string, size?: number, margin?: number, download?: boolean): URL {\n const apiPath = '/avatars/qr';\n const payload: Payload = {};\n\n if (typeof text !== 'undefined') {\n payload['text'] = text;\n }\n\n if (typeof size !== 'undefined') {\n payload['size'] = size;\n }\n\n if (typeof margin !== 'undefined') {\n payload['margin'] = margin;\n }\n\n if (typeof download !== 'undefined') {\n payload['download'] = download;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\n\nexport class Databases extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Get a list of all the user's documents in a given collection. You can use the query params to filter your results.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection).\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.listRows` instead.\n */\n listDocuments<Document extends Models.Document = Models.DefaultDocument>(params: { databaseId: string, collectionId: string, queries?: string[] }): Promise<Models.DocumentList<Document>>;\n /**\n * Get a list of all the user's documents in a given collection. You can use the query params to filter your results.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection).\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise<Models.DocumentList<Document>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n listDocuments<Document extends Models.Document = Models.DefaultDocument>(databaseId: string, collectionId: string, queries?: string[]): Promise<Models.DocumentList<Document>>;\n listDocuments<Document extends Models.Document = Models.DefaultDocument>(\n paramsOrFirst: { databaseId: string, collectionId: string, queries?: string[] } | string,\n ...rest: [(string)?, (string[])?] \n ): Promise<Models.DocumentList<Document>> {\n let params: { databaseId: string, collectionId: string, queries?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, queries?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n queries: rest[1] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const queries = params.queries;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId);\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Create a new Document. Before using this route, you should create a new collection resource using either a [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection) API or directly from your database console.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection). Make sure to define attributes before creating documents.\n * @param {string} params.documentId - Document ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>} params.data - Document data as JSON object.\n * @param {string[]} params.permissions - An array of permissions strings. By default, only the current user is granted all permissions. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.createRow` instead.\n */\n createDocument<Document extends Models.Document = Models.DefaultDocument>(params: { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>, permissions?: string[] }): Promise<Document>;\n /**\n * Create a new Document. Before using this route, you should create a new collection resource using either a [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection) API or directly from your database console.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection). Make sure to define attributes before creating documents.\n * @param {string} documentId - Document ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>} data - Document data as JSON object.\n * @param {string[]} permissions - An array of permissions strings. By default, only the current user is granted all permissions. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Document>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createDocument<Document extends Models.Document = Models.DefaultDocument>(databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>, permissions?: string[]): Promise<Document>;\n createDocument<Document extends Models.Document = Models.DefaultDocument>(\n paramsOrFirst: { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>, permissions?: string[] } | string,\n ...rest: [(string)?, (string)?, (Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>)?, (string[])?] \n ): Promise<Document> {\n let params: { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>, permissions?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>, permissions?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n documentId: rest[1] as string,\n data: rest[2] as Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>,\n permissions: rest[3] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const documentId = params.documentId;\n const data = params.data;\n const permissions = params.permissions;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n if (typeof documentId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"documentId\"');\n }\n\n if (typeof data === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"data\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId);\n const payload: Payload = {};\n\n if (typeof documentId !== 'undefined') {\n payload['documentId'] = documentId;\n }\n\n if (typeof data !== 'undefined') {\n payload['data'] = data;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get a document by its unique ID. This endpoint response returns a JSON object with the document data.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection).\n * @param {string} params.documentId - Document ID.\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.getRow` instead.\n */\n getDocument<Document extends Models.Document = Models.DefaultDocument>(params: { databaseId: string, collectionId: string, documentId: string, queries?: string[] }): Promise<Document>;\n /**\n * Get a document by its unique ID. This endpoint response returns a JSON object with the document data.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection).\n * @param {string} documentId - Document ID.\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise<Document>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getDocument<Document extends Models.Document = Models.DefaultDocument>(databaseId: string, collectionId: string, documentId: string, queries?: string[]): Promise<Document>;\n getDocument<Document extends Models.Document = Models.DefaultDocument>(\n paramsOrFirst: { databaseId: string, collectionId: string, documentId: string, queries?: string[] } | string,\n ...rest: [(string)?, (string)?, (string[])?] \n ): Promise<Document> {\n let params: { databaseId: string, collectionId: string, documentId: string, queries?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, documentId: string, queries?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n documentId: rest[1] as string,\n queries: rest[2] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const documentId = params.documentId;\n const queries = params.queries;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n if (typeof documentId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"documentId\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents/{documentId}'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId).replace('{documentId}', documentId);\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Create or update a Document. Before using this route, you should create a new collection resource using either a [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection) API or directly from your database console.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID.\n * @param {string} params.documentId - Document ID.\n * @param {Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>} params.data - Document data as JSON object. Include all required attributes of the document to be created or updated.\n * @param {string[]} params.permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.upsertRow` instead.\n */\n upsertDocument<Document extends Models.Document = Models.DefaultDocument>(params: { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] }): Promise<Document>;\n /**\n * Create or update a Document. Before using this route, you should create a new collection resource using either a [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection) API or directly from your database console.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID.\n * @param {string} documentId - Document ID.\n * @param {Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>} data - Document data as JSON object. Include all required attributes of the document to be created or updated.\n * @param {string[]} permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Document>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n upsertDocument<Document extends Models.Document = Models.DefaultDocument>(databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[]): Promise<Document>;\n upsertDocument<Document extends Models.Document = Models.DefaultDocument>(\n paramsOrFirst: { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] } | string,\n ...rest: [(string)?, (string)?, (Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>)?, (string[])?] \n ): Promise<Document> {\n let params: { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n documentId: rest[1] as string,\n data: rest[2] as Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>,\n permissions: rest[3] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const documentId = params.documentId;\n const data = params.data;\n const permissions = params.permissions;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n if (typeof documentId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"documentId\"');\n }\n\n if (typeof data === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"data\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents/{documentId}'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId).replace('{documentId}', documentId);\n const payload: Payload = {};\n\n if (typeof data !== 'undefined') {\n payload['data'] = data;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Update a document by its unique ID. Using the patch method you can pass only specific fields that will get updated.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID.\n * @param {string} params.documentId - Document ID.\n * @param {Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>} params.data - Document data as JSON object. Include only attribute and value pairs to be updated.\n * @param {string[]} params.permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.updateRow` instead.\n */\n updateDocument<Document extends Models.Document = Models.DefaultDocument>(params: { databaseId: string, collectionId: string, documentId: string, data?: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] }): Promise<Document>;\n /**\n * Update a document by its unique ID. Using the patch method you can pass only specific fields that will get updated.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID.\n * @param {string} documentId - Document ID.\n * @param {Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>} data - Document data as JSON object. Include only attribute and value pairs to be updated.\n * @param {string[]} permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Document>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateDocument<Document extends Models.Document = Models.DefaultDocument>(databaseId: string, collectionId: string, documentId: string, data?: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[]): Promise<Document>;\n updateDocument<Document extends Models.Document = Models.DefaultDocument>(\n paramsOrFirst: { databaseId: string, collectionId: string, documentId: string, data?: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] } | string,\n ...rest: [(string)?, (string)?, (Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>)?, (string[])?] \n ): Promise<Document> {\n let params: { databaseId: string, collectionId: string, documentId: string, data?: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, documentId: string, data?: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n documentId: rest[1] as string,\n data: rest[2] as Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>,\n permissions: rest[3] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const documentId = params.documentId;\n const data = params.data;\n const permissions = params.permissions;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n if (typeof documentId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"documentId\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents/{documentId}'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId).replace('{documentId}', documentId);\n const payload: Payload = {};\n\n if (typeof data !== 'undefined') {\n payload['data'] = data;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete a document by its unique ID.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection).\n * @param {string} params.documentId - Document ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.deleteRow` instead.\n */\n deleteDocument(params: { databaseId: string, collectionId: string, documentId: string }): Promise<{}>;\n /**\n * Delete a document by its unique ID.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection).\n * @param {string} documentId - Document ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteDocument(databaseId: string, collectionId: string, documentId: string): Promise<{}>;\n deleteDocument(\n paramsOrFirst: { databaseId: string, collectionId: string, documentId: string } | string,\n ...rest: [(string)?, (string)?] \n ): Promise<{}> {\n let params: { databaseId: string, collectionId: string, documentId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, documentId: string };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n documentId: rest[1] as string \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const documentId = params.documentId;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n if (typeof documentId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"documentId\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents/{documentId}'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId).replace('{documentId}', documentId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Decrement a specific attribute of a document by a given value.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID.\n * @param {string} params.documentId - Document ID.\n * @param {string} params.attribute - Attribute key.\n * @param {number} params.value - Value to increment the attribute by. The value must be a number.\n * @param {number} params.min - Minimum value for the attribute. If the current value is lesser than this value, an exception will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.decrementRowColumn` instead.\n */\n decrementDocumentAttribute<Document extends Models.Document = Models.DefaultDocument>(params: { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, min?: number }): Promise<Document>;\n /**\n * Decrement a specific attribute of a document by a given value.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID.\n * @param {string} documentId - Document ID.\n * @param {string} attribute - Attribute key.\n * @param {number} value - Value to increment the attribute by. The value must be a number.\n * @param {number} min - Minimum value for the attribute. If the current value is lesser than this value, an exception will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise<Document>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n decrementDocumentAttribute<Document extends Models.Document = Models.DefaultDocument>(databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, min?: number): Promise<Document>;\n decrementDocumentAttribute<Document extends Models.Document = Models.DefaultDocument>(\n paramsOrFirst: { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, min?: number } | string,\n ...rest: [(string)?, (string)?, (string)?, (number)?, (number)?] \n ): Promise<Document> {\n let params: { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, min?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, min?: number };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n documentId: rest[1] as string,\n attribute: rest[2] as string,\n value: rest[3] as number,\n min: rest[4] as number \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const documentId = params.documentId;\n const attribute = params.attribute;\n const value = params.value;\n const min = params.min;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n if (typeof documentId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"documentId\"');\n }\n\n if (typeof attribute === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"attribute\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents/{documentId}/{attribute}/decrement'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId).replace('{documentId}', documentId).replace('{attribute}', attribute);\n const payload: Payload = {};\n\n if (typeof value !== 'undefined') {\n payload['value'] = value;\n }\n\n if (typeof min !== 'undefined') {\n payload['min'] = min;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Increment a specific attribute of a document by a given value.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID.\n * @param {string} params.documentId - Document ID.\n * @param {string} params.attribute - Attribute key.\n * @param {number} params.value - Value to increment the attribute by. The value must be a number.\n * @param {number} params.max - Maximum value for the attribute. If the current value is greater than this value, an error will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.incrementRowColumn` instead.\n */\n incrementDocumentAttribute<Document extends Models.Document = Models.DefaultDocument>(params: { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, max?: number }): Promise<Document>;\n /**\n * Increment a specific attribute of a document by a given value.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID.\n * @param {string} documentId - Document ID.\n * @param {string} attribute - Attribute key.\n * @param {number} value - Value to increment the attribute by. The value must be a number.\n * @param {number} max - Maximum value for the attribute. If the current value is greater than this value, an error will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise<Document>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n incrementDocumentAttribute<Document extends Models.Document = Models.DefaultDocument>(databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, max?: number): Promise<Document>;\n incrementDocumentAttribute<Document extends Models.Document = Models.DefaultDocument>(\n paramsOrFirst: { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, max?: number } | string,\n ...rest: [(string)?, (string)?, (string)?, (number)?, (number)?] \n ): Promise<Document> {\n let params: { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, max?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, max?: number };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n documentId: rest[1] as string,\n attribute: rest[2] as string,\n value: rest[3] as number,\n max: rest[4] as number \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const documentId = params.documentId;\n const attribute = params.attribute;\n const value = params.value;\n const max = params.max;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n if (typeof documentId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"documentId\"');\n }\n\n if (typeof attribute === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"attribute\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents/{documentId}/{attribute}/increment'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId).replace('{documentId}', documentId).replace('{attribute}', attribute);\n const payload: Payload = {};\n\n if (typeof value !== 'undefined') {\n payload['value'] = value;\n }\n\n if (typeof max !== 'undefined') {\n payload['max'] = max;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\nimport { ExecutionMethod } from '../enums/execution-method';\n\nexport class Functions extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Get a list of all the current user function execution logs. You can use the query params to filter your results.\n *\n * @param {string} params.functionId - Function ID.\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: trigger, status, responseStatusCode, duration, requestMethod, requestPath, deploymentId\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listExecutions(params: { functionId: string, queries?: string[] }): Promise<Models.ExecutionList>;\n /**\n * Get a list of all the current user function execution logs. You can use the query params to filter your results.\n *\n * @param {string} functionId - Function ID.\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: trigger, status, responseStatusCode, duration, requestMethod, requestPath, deploymentId\n * @throws {AppwriteException}\n * @returns {Promise<Models.ExecutionList>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n listExecutions(functionId: string, queries?: string[]): Promise<Models.ExecutionList>;\n listExecutions(\n paramsOrFirst: { functionId: string, queries?: string[] } | string,\n ...rest: [(string[])?] \n ): Promise<Models.ExecutionList> {\n let params: { functionId: string, queries?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { functionId: string, queries?: string[] };\n } else {\n params = {\n functionId: paramsOrFirst as string,\n queries: rest[0] as string[] \n };\n }\n\n const functionId = params.functionId;\n const queries = params.queries;\n\n if (typeof functionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"functionId\"');\n }\n\n const apiPath = '/functions/{functionId}/executions'.replace('{functionId}', functionId);\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Trigger a function execution. The returned object will return you the current execution status. You can ping the `Get Execution` endpoint to get updates on the current execution status. Once this endpoint is called, your function execution process will start asynchronously.\n *\n * @param {string} params.functionId - Function ID.\n * @param {string} params.body - HTTP body of execution. Default value is empty string.\n * @param {boolean} params.async - Execute code in the background. Default value is false.\n * @param {string} params.xpath - HTTP path of execution. Path can include query params. Default value is /\n * @param {ExecutionMethod} params.method - HTTP method of execution. Default value is POST.\n * @param {object} params.headers - HTTP headers of execution. Defaults to empty.\n * @param {string} params.scheduledAt - Scheduled execution time in [ISO 8601](https://www.iso.org/iso-8601-date-and-time-format.html) format. DateTime value must be in future with precision in minutes.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createExecution(params: { functionId: string, body?: string, async?: boolean, xpath?: string, method?: ExecutionMethod, headers?: object, scheduledAt?: string }): Promise<Models.Execution>;\n /**\n * Trigger a function execution. The returned object will return you the current execution status. You can ping the `Get Execution` endpoint to get updates on the current execution status. Once this endpoint is called, your function execution process will start asynchronously.\n *\n * @param {string} functionId - Function ID.\n * @param {string} body - HTTP body of execution. Default value is empty string.\n * @param {boolean} async - Execute code in the background. Default value is false.\n * @param {string} xpath - HTTP path of execution. Path can include query params. Default value is /\n * @param {ExecutionMethod} method - HTTP method of execution. Default value is POST.\n * @param {object} headers - HTTP headers of execution. Defaults to empty.\n * @param {string} scheduledAt - Scheduled execution time in [ISO 8601](https://www.iso.org/iso-8601-date-and-time-format.html) format. DateTime value must be in future with precision in minutes.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Execution>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createExecution(functionId: string, body?: string, async?: boolean, xpath?: string, method?: ExecutionMethod, headers?: object, scheduledAt?: string): Promise<Models.Execution>;\n createExecution(\n paramsOrFirst: { functionId: string, body?: string, async?: boolean, xpath?: string, method?: ExecutionMethod, headers?: object, scheduledAt?: string } | string,\n ...rest: [(string)?, (boolean)?, (string)?, (ExecutionMethod)?, (object)?, (string)?] \n ): Promise<Models.Execution> {\n let params: { functionId: string, body?: string, async?: boolean, xpath?: string, method?: ExecutionMethod, headers?: object, scheduledAt?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { functionId: string, body?: string, async?: boolean, xpath?: string, method?: ExecutionMethod, headers?: object, scheduledAt?: string };\n } else {\n params = {\n functionId: paramsOrFirst as string,\n body: rest[0] as string,\n async: rest[1] as boolean,\n xpath: rest[2] as string,\n method: rest[3] as ExecutionMethod,\n headers: rest[4] as object,\n scheduledAt: rest[5] as string \n };\n }\n\n const functionId = params.functionId;\n const body = params.body;\n const async = params.async;\n const xpath = params.xpath;\n const method = params.method;\n const headers = params.headers;\n const scheduledAt = params.scheduledAt;\n\n if (typeof functionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"functionId\"');\n }\n\n const apiPath = '/functions/{functionId}/executions'.replace('{functionId}', functionId);\n const payload: Payload = {};\n\n if (typeof body !== 'undefined') {\n payload['body'] = body;\n }\n\n if (typeof async !== 'undefined') {\n payload['async'] = async;\n }\n\n if (typeof xpath !== 'undefined') {\n payload['path'] = xpath;\n }\n\n if (typeof method !== 'undefined') {\n payload['method'] = method;\n }\n\n if (typeof headers !== 'undefined') {\n payload['headers'] = headers;\n }\n\n if (typeof scheduledAt !== 'undefined') {\n payload['scheduledAt'] = scheduledAt;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get a function execution log by its unique ID.\n *\n * @param {string} params.functionId - Function ID.\n * @param {string} params.executionId - Execution ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getExecution(params: { functionId: string, executionId: string }): Promise<Models.Execution>;\n /**\n * Get a function execution log by its unique ID.\n *\n * @param {string} functionId - Function ID.\n * @param {string} executionId - Execution ID.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Execution>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getExecution(functionId: string, executionId: string): Promise<Models.Execution>;\n getExecution(\n paramsOrFirst: { functionId: string, executionId: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Execution> {\n let params: { functionId: string, executionId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { functionId: string, executionId: string };\n } else {\n params = {\n functionId: paramsOrFirst as string,\n executionId: rest[0] as string \n };\n }\n\n const functionId = params.functionId;\n const executionId = params.executionId;\n\n if (typeof functionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"functionId\"');\n }\n\n if (typeof executionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"executionId\"');\n }\n\n const apiPath = '/functions/{functionId}/executions/{executionId}'.replace('{functionId}', functionId).replace('{executionId}', executionId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\n\nexport class Graphql extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Execute a GraphQL mutation.\n *\n * @param {object} params.query - The query or queries to execute.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n query(params: { query: object }): Promise<{}>;\n /**\n * Execute a GraphQL mutation.\n *\n * @param {object} query - The query or queries to execute.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n query(query: object): Promise<{}>;\n query(\n paramsOrFirst: { query: object } | object \n ): Promise<{}> {\n let params: { query: object };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'query' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { query: object };\n } else {\n params = {\n query: paramsOrFirst as object \n };\n }\n\n const query = params.query;\n\n if (typeof query === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"query\"');\n }\n\n const apiPath = '/graphql';\n const payload: Payload = {};\n\n if (typeof query !== 'undefined') {\n payload['query'] = query;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'x-sdk-graphql': 'true',\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Execute a GraphQL mutation.\n *\n * @param {object} params.query - The query or queries to execute.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n mutation(params: { query: object }): Promise<{}>;\n /**\n * Execute a GraphQL mutation.\n *\n * @param {object} query - The query or queries to execute.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n mutation(query: object): Promise<{}>;\n mutation(\n paramsOrFirst: { query: object } | object \n ): Promise<{}> {\n let params: { query: object };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'query' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { query: object };\n } else {\n params = {\n query: paramsOrFirst as object \n };\n }\n\n const query = params.query;\n\n if (typeof query === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"query\"');\n }\n\n const apiPath = '/graphql/mutation';\n const payload: Payload = {};\n\n if (typeof query !== 'undefined') {\n payload['query'] = query;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'x-sdk-graphql': 'true',\n 'content-type': 'application/json',\n }, payload);\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\n\nexport class Locale extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Get the current user location based on IP. Returns an object with user country code, country name, continent name, continent code, ip address and suggested currency. You can use the locale header to get the data in a supported language.\n * \n * ([IP Geolocation by DB-IP](https://db-ip.com))\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n get(): Promise<Models.Locale> {\n const apiPath = '/locale';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List of all locale codes in [ISO 639-1](https://en.wikipedia.org/wiki/List_of_ISO_639-1_codes).\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listCodes(): Promise<Models.LocaleCodeList> {\n const apiPath = '/locale/codes';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List of all continents. You can use the locale header to get the data in a supported language.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listContinents(): Promise<Models.ContinentList> {\n const apiPath = '/locale/continents';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List of all countries. You can use the locale header to get the data in a supported language.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listCountries(): Promise<Models.CountryList> {\n const apiPath = '/locale/countries';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List of all countries that are currently members of the EU. You can use the locale header to get the data in a supported language.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listCountriesEU(): Promise<Models.CountryList> {\n const apiPath = '/locale/countries/eu';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List of all countries phone codes. You can use the locale header to get the data in a supported language.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listCountriesPhones(): Promise<Models.PhoneList> {\n const apiPath = '/locale/countries/phones';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List of all currencies, including currency symbol, name, plural, and decimal digits for all major and minor currencies. You can use the locale header to get the data in a supported language.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listCurrencies(): Promise<Models.CurrencyList> {\n const apiPath = '/locale/currencies';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List of all languages classified by ISO 639-1 including 2-letter code, name in English, and name in the respective language.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listLanguages(): Promise<Models.LanguageList> {\n const apiPath = '/locale/languages';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\n\nexport class Messaging extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Create a new subscriber.\n *\n * @param {string} params.topicId - Topic ID. The topic ID to subscribe to.\n * @param {string} params.subscriberId - Subscriber ID. Choose a custom Subscriber ID or a new Subscriber ID.\n * @param {string} params.targetId - Target ID. The target ID to link to the specified Topic ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createSubscriber(params: { topicId: string, subscriberId: string, targetId: string }): Promise<Models.Subscriber>;\n /**\n * Create a new subscriber.\n *\n * @param {string} topicId - Topic ID. The topic ID to subscribe to.\n * @param {string} subscriberId - Subscriber ID. Choose a custom Subscriber ID or a new Subscriber ID.\n * @param {string} targetId - Target ID. The target ID to link to the specified Topic ID.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Subscriber>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createSubscriber(topicId: string, subscriberId: string, targetId: string): Promise<Models.Subscriber>;\n createSubscriber(\n paramsOrFirst: { topicId: string, subscriberId: string, targetId: string } | string,\n ...rest: [(string)?, (string)?] \n ): Promise<Models.Subscriber> {\n let params: { topicId: string, subscriberId: string, targetId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { topicId: string, subscriberId: string, targetId: string };\n } else {\n params = {\n topicId: paramsOrFirst as string,\n subscriberId: rest[0] as string,\n targetId: rest[1] as string \n };\n }\n\n const topicId = params.topicId;\n const subscriberId = params.subscriberId;\n const targetId = params.targetId;\n\n if (typeof topicId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"topicId\"');\n }\n\n if (typeof subscriberId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"subscriberId\"');\n }\n\n if (typeof targetId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"targetId\"');\n }\n\n const apiPath = '/messaging/topics/{topicId}/subscribers'.replace('{topicId}', topicId);\n const payload: Payload = {};\n\n if (typeof subscriberId !== 'undefined') {\n payload['subscriberId'] = subscriberId;\n }\n\n if (typeof targetId !== 'undefined') {\n payload['targetId'] = targetId;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete a subscriber by its unique ID.\n *\n * @param {string} params.topicId - Topic ID. The topic ID subscribed to.\n * @param {string} params.subscriberId - Subscriber ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteSubscriber(params: { topicId: string, subscriberId: string }): Promise<{}>;\n /**\n * Delete a subscriber by its unique ID.\n *\n * @param {string} topicId - Topic ID. The topic ID subscribed to.\n * @param {string} subscriberId - Subscriber ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteSubscriber(topicId: string, subscriberId: string): Promise<{}>;\n deleteSubscriber(\n paramsOrFirst: { topicId: string, subscriberId: string } | string,\n ...rest: [(string)?] \n ): Promise<{}> {\n let params: { topicId: string, subscriberId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { topicId: string, subscriberId: string };\n } else {\n params = {\n topicId: paramsOrFirst as string,\n subscriberId: rest[0] as string \n };\n }\n\n const topicId = params.topicId;\n const subscriberId = params.subscriberId;\n\n if (typeof topicId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"topicId\"');\n }\n\n if (typeof subscriberId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"subscriberId\"');\n }\n\n const apiPath = '/messaging/topics/{topicId}/subscribers/{subscriberId}'.replace('{topicId}', topicId).replace('{subscriberId}', subscriberId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\nimport { ImageGravity } from '../enums/image-gravity';\nimport { ImageFormat } from '../enums/image-format';\n\nexport class Storage extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Get a list of all the user files. You can use the query params to filter your results.\n *\n * @param {string} params.bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: name, signature, mimeType, sizeOriginal, chunksTotal, chunksUploaded\n * @param {string} params.search - Search term to filter your list results. Max length: 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listFiles(params: { bucketId: string, queries?: string[], search?: string }): Promise<Models.FileList>;\n /**\n * Get a list of all the user files. You can use the query params to filter your results.\n *\n * @param {string} bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: name, signature, mimeType, sizeOriginal, chunksTotal, chunksUploaded\n * @param {string} search - Search term to filter your list results. Max length: 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.FileList>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n listFiles(bucketId: string, queries?: string[], search?: string): Promise<Models.FileList>;\n listFiles(\n paramsOrFirst: { bucketId: string, queries?: string[], search?: string } | string,\n ...rest: [(string[])?, (string)?] \n ): Promise<Models.FileList> {\n let params: { bucketId: string, queries?: string[], search?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, queries?: string[], search?: string };\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n queries: rest[0] as string[],\n search: rest[1] as string \n };\n }\n\n const bucketId = params.bucketId;\n const queries = params.queries;\n const search = params.search;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files'.replace('{bucketId}', bucketId);\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n if (typeof search !== 'undefined') {\n payload['search'] = search;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Create a new file. Before using this route, you should create a new bucket resource using either a [server integration](https://appwrite.io/docs/server/storage#storageCreateBucket) API or directly from your Appwrite console.\n * \n * Larger files should be uploaded using multiple requests with the [content-range](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Range) header to send a partial request with a maximum supported chunk of `5MB`. The `content-range` header values should always be in bytes.\n * \n * When the first request is sent, the server will return the **File** object, and the subsequent part request must include the file's **id** in `x-appwrite-id` header to allow the server to know that the partial upload is for the existing file and not for a new one.\n * \n * If you're creating a new file using one of the Appwrite SDKs, all the chunking logic will be managed by the SDK internally.\n * \n *\n * @param {string} params.bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} params.fileId - File ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {{name: string, type: string, size: number, uri: string}} params.file - Binary file. Appwrite SDKs provide helpers to handle file input. [Learn about file input](https://appwrite.io/docs/products/storage/upload-download#input-file).\n * @param {string[]} params.permissions - An array of permission strings. By default, only the current user is granted all permissions. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n async createFile(params: { bucketId: string, fileId: string, file: {name: string, type: string, size: number, uri: string}, permissions?: string[] , onProgress?: (progress: UploadProgress) => void }): Promise<Models.File>;\n /**\n * Create a new file. Before using this route, you should create a new bucket resource using either a [server integration](https://appwrite.io/docs/server/storage#storageCreateBucket) API or directly from your Appwrite console.\n * \n * Larger files should be uploaded using multiple requests with the [content-range](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Range) header to send a partial request with a maximum supported chunk of `5MB`. The `content-range` header values should always be in bytes.\n * \n * When the first request is sent, the server will return the **File** object, and the subsequent part request must include the file's **id** in `x-appwrite-id` header to allow the server to know that the partial upload is for the existing file and not for a new one.\n * \n * If you're creating a new file using one of the Appwrite SDKs, all the chunking logic will be managed by the SDK internally.\n * \n *\n * @param {string} bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} fileId - File ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {{name: string, type: string, size: number, uri: string}} file - Binary file. Appwrite SDKs provide helpers to handle file input. [Learn about file input](https://appwrite.io/docs/products/storage/upload-download#input-file).\n * @param {string[]} permissions - An array of permission strings. By default, only the current user is granted all permissions. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Models.File>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n async createFile(bucketId: string, fileId: string, file: {name: string, type: string, size: number, uri: string}, permissions?: string[], onProgress?: (progress: UploadProgress) => void): Promise<Models.File>;\n async createFile(\n paramsOrFirst: { bucketId: string, fileId: string, file: {name: string, type: string, size: number, uri: string}, permissions?: string[], onProgress?: (progress: UploadProgress) => void } | string,\n ...rest: [(string)?, ({name: string, type: string, size: number, uri: string})?, (string[])?,((progress: UploadProgress) => void)?] \n ): Promise<Models.File> {\n let params: { bucketId: string, fileId: string, file: {name: string, type: string, size: number, uri: string}, permissions?: string[] };\n let onProgress: ((progress: UploadProgress) => void);\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, fileId: string, file: {name: string, type: string, size: number, uri: string}, permissions?: string[] };\n onProgress = paramsOrFirst?.onProgress as ((progress: UploadProgress) => void);\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n fileId: rest[0] as string,\n file: rest[1] as {name: string, type: string, size: number, uri: string},\n permissions: rest[2] as string[] \n };\n onProgress = rest[3] as ((progress: UploadProgress) => void);\n }\n\n const bucketId = params.bucketId;\n const fileId = params.fileId;\n const file = params.file;\n const permissions = params.permissions;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n if (typeof fileId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"fileId\"');\n }\n\n if (typeof file === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"file\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files'.replace('{bucketId}', bucketId);\n const payload: Payload = {};\n\n if (typeof fileId !== 'undefined') {\n payload['fileId'] = fileId;\n }\n\n if (typeof file !== 'undefined') {\n payload['file'] = file;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n\n const size = file.size;\n\n if (size <= Service.CHUNK_SIZE) {\n return this.client.call('post', uri, {\n 'content-type': 'multipart/form-data',\n }, payload);\n }\n\n const apiHeaders: { [header: string]: string } = {\n 'content-type': 'multipart/form-data',\n }\n\n let offset = 0;\n let response = undefined;\n try {\n response = await this.client.call('GET', new URL(this.client.config.endpoint + apiPath + '/' + fileId), apiHeaders);\n offset = response.chunksUploaded * Service.CHUNK_SIZE;\n } catch(e) {\n }\n\n let timestamp = new Date().getTime();\n while (offset < size) {\n let end = Math.min(offset + Service.CHUNK_SIZE - 1, size - 1);\n\n apiHeaders['content-range'] = 'bytes ' + offset + '-' + end + '/' + size;\n if (response && response.$id) {\n apiHeaders['x-appwrite-id'] = response.$id;\n }\n\n let chunk = await FileSystem.readAsStringAsync(file.uri, {\n encoding: FileSystem.EncodingType.Base64,\n position: offset,\n length: Service.CHUNK_SIZE\n });\n var path = `data:${file.type};base64,${chunk}`;\n if (Platform.OS.toLowerCase() === 'android') {\n path = FileSystem.cacheDirectory + '/tmp_chunk_' + timestamp;\n await FileSystem.writeAsStringAsync(path, chunk, {encoding: FileSystem.EncodingType.Base64});\n }\n\n payload['file'] = { uri: path, name: file.name, type: file.type };\n\n response = await this.client.call('post', uri, apiHeaders, payload);\n\n if (onProgress) {\n onProgress({\n $id: response.$id,\n progress: (offset / size) * 100,\n sizeUploaded: offset,\n chunksTotal: response.chunksTotal,\n chunksUploaded: response.chunksUploaded\n });\n }\n offset += Service.CHUNK_SIZE;\n }\n return response;\n }\n\n /**\n * Get a file by its unique ID. This endpoint response returns a JSON object with the file metadata.\n *\n * @param {string} params.bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} params.fileId - File ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getFile(params: { bucketId: string, fileId: string }): Promise<Models.File>;\n /**\n * Get a file by its unique ID. This endpoint response returns a JSON object with the file metadata.\n *\n * @param {string} bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} fileId - File ID.\n * @throws {AppwriteException}\n * @returns {Promise<Models.File>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getFile(bucketId: string, fileId: string): Promise<Models.File>;\n getFile(\n paramsOrFirst: { bucketId: string, fileId: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.File> {\n let params: { bucketId: string, fileId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, fileId: string };\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n fileId: rest[0] as string \n };\n }\n\n const bucketId = params.bucketId;\n const fileId = params.fileId;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n if (typeof fileId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"fileId\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Update a file by its unique ID. Only users with write permissions have access to update this resource.\n *\n * @param {string} params.bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} params.fileId - File unique ID.\n * @param {string} params.name - Name of the file\n * @param {string[]} params.permissions - An array of permission string. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateFile(params: { bucketId: string, fileId: string, name?: string, permissions?: string[] }): Promise<Models.File>;\n /**\n * Update a file by its unique ID. Only users with write permissions have access to update this resource.\n *\n * @param {string} bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} fileId - File unique ID.\n * @param {string} name - Name of the file\n * @param {string[]} permissions - An array of permission string. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Models.File>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateFile(bucketId: string, fileId: string, name?: string, permissions?: string[]): Promise<Models.File>;\n updateFile(\n paramsOrFirst: { bucketId: string, fileId: string, name?: string, permissions?: string[] } | string,\n ...rest: [(string)?, (string)?, (string[])?] \n ): Promise<Models.File> {\n let params: { bucketId: string, fileId: string, name?: string, permissions?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, fileId: string, name?: string, permissions?: string[] };\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n fileId: rest[0] as string,\n name: rest[1] as string,\n permissions: rest[2] as string[] \n };\n }\n\n const bucketId = params.bucketId;\n const fileId = params.fileId;\n const name = params.name;\n const permissions = params.permissions;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n if (typeof fileId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"fileId\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete a file by its unique ID. Only users with write permissions have access to delete this resource.\n *\n * @param {string} params.bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} params.fileId - File ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteFile(params: { bucketId: string, fileId: string }): Promise<{}>;\n /**\n * Delete a file by its unique ID. Only users with write permissions have access to delete this resource.\n *\n * @param {string} bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} fileId - File ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteFile(bucketId: string, fileId: string): Promise<{}>;\n deleteFile(\n paramsOrFirst: { bucketId: string, fileId: string } | string,\n ...rest: [(string)?] \n ): Promise<{}> {\n let params: { bucketId: string, fileId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, fileId: string };\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n fileId: rest[0] as string \n };\n }\n\n const bucketId = params.bucketId;\n const fileId = params.fileId;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n if (typeof fileId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"fileId\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get a file content by its unique ID. The endpoint response return with a 'Content-Disposition: attachment' header that tells the browser to start downloading the file to user downloads directory.\n *\n * @param {string} params.bucketId - Storage bucket ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} params.fileId - File ID.\n * @param {string} params.token - File token for accessing this file.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getFileDownload(params: { bucketId: string, fileId: string, token?: string }): Promise<ArrayBuffer>;\n /**\n * Get a file content by its unique ID. The endpoint response return with a 'Content-Disposition: attachment' header that tells the browser to start downloading the file to user downloads directory.\n *\n * @param {string} bucketId - Storage bucket ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} fileId - File ID.\n * @param {string} token - File token for accessing this file.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getFileDownload(bucketId: string, fileId: string, token?: string): Promise<ArrayBuffer>;\n getFileDownload(\n paramsOrFirst: { bucketId: string, fileId: string, token?: string } | string,\n ...rest: [(string)?, (string)?] \n ): Promise<ArrayBuffer> {\n let params: { bucketId: string, fileId: string, token?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, fileId: string, token?: string };\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n fileId: rest[0] as string,\n token: rest[1] as string \n };\n }\n\n const bucketId = params.bucketId;\n const fileId = params.fileId;\n const token = params.token;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n if (typeof fileId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"fileId\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}/download'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n if (typeof token !== 'undefined') {\n payload['token'] = token;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * Get a file preview image. Currently, this method supports preview for image files (jpg, png, and gif), other supported formats, like pdf, docs, slides, and spreadsheets, will return the file icon image. You can also pass query string arguments for cutting and resizing your preview image. Preview is supported only for image files smaller than 10MB.\n *\n * @param {string} params.bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} params.fileId - File ID\n * @param {number} params.width - Resize preview image width, Pass an integer between 0 to 4000.\n * @param {number} params.height - Resize preview image height, Pass an integer between 0 to 4000.\n * @param {ImageGravity} params.gravity - Image crop gravity. Can be one of center,top-left,top,top-right,left,right,bottom-left,bottom,bottom-right\n * @param {number} params.quality - Preview image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @param {number} params.borderWidth - Preview image border in pixels. Pass an integer between 0 to 100. Defaults to 0.\n * @param {string} params.borderColor - Preview image border color. Use a valid HEX color, no # is needed for prefix.\n * @param {number} params.borderRadius - Preview image border radius in pixels. Pass an integer between 0 to 4000.\n * @param {number} params.opacity - Preview image opacity. Only works with images having an alpha channel (like png). Pass a number between 0 to 1.\n * @param {number} params.rotation - Preview image rotation in degrees. Pass an integer between -360 and 360.\n * @param {string} params.background - Preview image background color. Only works with transparent images (png). Use a valid HEX color, no # is needed for prefix.\n * @param {ImageFormat} params.output - Output format type (jpeg, jpg, png, gif and webp).\n * @param {string} params.token - File token for accessing this file.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getFilePreview(params: { bucketId: string, fileId: string, width?: number, height?: number, gravity?: ImageGravity, quality?: number, borderWidth?: number, borderColor?: string, borderRadius?: number, opacity?: number, rotation?: number, background?: string, output?: ImageFormat, token?: string }): Promise<ArrayBuffer>;\n /**\n * Get a file preview image. Currently, this method supports preview for image files (jpg, png, and gif), other supported formats, like pdf, docs, slides, and spreadsheets, will return the file icon image. You can also pass query string arguments for cutting and resizing your preview image. Preview is supported only for image files smaller than 10MB.\n *\n * @param {string} bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} fileId - File ID\n * @param {number} width - Resize preview image width, Pass an integer between 0 to 4000.\n * @param {number} height - Resize preview image height, Pass an integer between 0 to 4000.\n * @param {ImageGravity} gravity - Image crop gravity. Can be one of center,top-left,top,top-right,left,right,bottom-left,bottom,bottom-right\n * @param {number} quality - Preview image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @param {number} borderWidth - Preview image border in pixels. Pass an integer between 0 to 100. Defaults to 0.\n * @param {string} borderColor - Preview image border color. Use a valid HEX color, no # is needed for prefix.\n * @param {number} borderRadius - Preview image border radius in pixels. Pass an integer between 0 to 4000.\n * @param {number} opacity - Preview image opacity. Only works with images having an alpha channel (like png). Pass a number between 0 to 1.\n * @param {number} rotation - Preview image rotation in degrees. Pass an integer between -360 and 360.\n * @param {string} background - Preview image background color. Only works with transparent images (png). Use a valid HEX color, no # is needed for prefix.\n * @param {ImageFormat} output - Output format type (jpeg, jpg, png, gif and webp).\n * @param {string} token - File token for accessing this file.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getFilePreview(bucketId: string, fileId: string, width?: number, height?: number, gravity?: ImageGravity, quality?: number, borderWidth?: number, borderColor?: string, borderRadius?: number, opacity?: number, rotation?: number, background?: string, output?: ImageFormat, token?: string): Promise<ArrayBuffer>;\n getFilePreview(\n paramsOrFirst: { bucketId: string, fileId: string, width?: number, height?: number, gravity?: ImageGravity, quality?: number, borderWidth?: number, borderColor?: string, borderRadius?: number, opacity?: number, rotation?: number, background?: string, output?: ImageFormat, token?: string } | string,\n ...rest: [(string)?, (number)?, (number)?, (ImageGravity)?, (number)?, (number)?, (string)?, (number)?, (number)?, (number)?, (string)?, (ImageFormat)?, (string)?] \n ): Promise<ArrayBuffer> {\n let params: { bucketId: string, fileId: string, width?: number, height?: number, gravity?: ImageGravity, quality?: number, borderWidth?: number, borderColor?: string, borderRadius?: number, opacity?: number, rotation?: number, background?: string, output?: ImageFormat, token?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, fileId: string, width?: number, height?: number, gravity?: ImageGravity, quality?: number, borderWidth?: number, borderColor?: string, borderRadius?: number, opacity?: number, rotation?: number, background?: string, output?: ImageFormat, token?: string };\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n fileId: rest[0] as string,\n width: rest[1] as number,\n height: rest[2] as number,\n gravity: rest[3] as ImageGravity,\n quality: rest[4] as number,\n borderWidth: rest[5] as number,\n borderColor: rest[6] as string,\n borderRadius: rest[7] as number,\n opacity: rest[8] as number,\n rotation: rest[9] as number,\n background: rest[10] as string,\n output: rest[11] as ImageFormat,\n token: rest[12] as string \n };\n }\n\n const bucketId = params.bucketId;\n const fileId = params.fileId;\n const width = params.width;\n const height = params.height;\n const gravity = params.gravity;\n const quality = params.quality;\n const borderWidth = params.borderWidth;\n const borderColor = params.borderColor;\n const borderRadius = params.borderRadius;\n const opacity = params.opacity;\n const rotation = params.rotation;\n const background = params.background;\n const output = params.output;\n const token = params.token;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n if (typeof fileId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"fileId\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}/preview'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof gravity !== 'undefined') {\n payload['gravity'] = gravity;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n if (typeof borderWidth !== 'undefined') {\n payload['borderWidth'] = borderWidth;\n }\n\n if (typeof borderColor !== 'undefined') {\n payload['borderColor'] = borderColor;\n }\n\n if (typeof borderRadius !== 'undefined') {\n payload['borderRadius'] = borderRadius;\n }\n\n if (typeof opacity !== 'undefined') {\n payload['opacity'] = opacity;\n }\n\n if (typeof rotation !== 'undefined') {\n payload['rotation'] = rotation;\n }\n\n if (typeof background !== 'undefined') {\n payload['background'] = background;\n }\n\n if (typeof output !== 'undefined') {\n payload['output'] = output;\n }\n\n if (typeof token !== 'undefined') {\n payload['token'] = token;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * Get a file content by its unique ID. This endpoint is similar to the download method but returns with no 'Content-Disposition: attachment' header.\n *\n * @param {string} params.bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} params.fileId - File ID.\n * @param {string} params.token - File token for accessing this file.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getFileView(params: { bucketId: string, fileId: string, token?: string }): Promise<ArrayBuffer>;\n /**\n * Get a file content by its unique ID. This endpoint is similar to the download method but returns with no 'Content-Disposition: attachment' header.\n *\n * @param {string} bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} fileId - File ID.\n * @param {string} token - File token for accessing this file.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getFileView(bucketId: string, fileId: string, token?: string): Promise<ArrayBuffer>;\n getFileView(\n paramsOrFirst: { bucketId: string, fileId: string, token?: string } | string,\n ...rest: [(string)?, (string)?] \n ): Promise<ArrayBuffer> {\n let params: { bucketId: string, fileId: string, token?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, fileId: string, token?: string };\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n fileId: rest[0] as string,\n token: rest[1] as string \n };\n }\n\n const bucketId = params.bucketId;\n const fileId = params.fileId;\n const token = params.token;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n if (typeof fileId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"fileId\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}/view'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n if (typeof token !== 'undefined') {\n payload['token'] = token;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * Get a file content by its unique ID. The endpoint response return with a\n * 'Content-Disposition: attachment' header that tells the browser to start\n * downloading the file to user downloads directory.\n *\n * @param {string} bucketId\n * @param {string} fileId\n * @param {string} token\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getFileDownloadURL(bucketId: string, fileId: string, token?: string): URL {\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}/download'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n if (typeof token !== 'undefined') {\n payload['token'] = token;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * Get a file preview image. Currently, this method supports preview for image\n * files (jpg, png, and gif), other supported formats, like pdf, docs, slides,\n * and spreadsheets, will return the file icon image. You can also pass query\n * string arguments for cutting and resizing your preview image. Preview is\n * supported only for image files smaller than 10MB.\n *\n * @param {string} bucketId\n * @param {string} fileId\n * @param {number} width\n * @param {number} height\n * @param {ImageGravity} gravity\n * @param {number} quality\n * @param {number} borderWidth\n * @param {string} borderColor\n * @param {number} borderRadius\n * @param {number} opacity\n * @param {number} rotation\n * @param {string} background\n * @param {ImageFormat} output\n * @param {string} token\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getFilePreviewURL(bucketId: string, fileId: string, width?: number, height?: number, gravity?: ImageGravity, quality?: number, borderWidth?: number, borderColor?: string, borderRadius?: number, opacity?: number, rotation?: number, background?: string, output?: ImageFormat, token?: string): URL {\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}/preview'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof gravity !== 'undefined') {\n payload['gravity'] = gravity;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n if (typeof borderWidth !== 'undefined') {\n payload['borderWidth'] = borderWidth;\n }\n\n if (typeof borderColor !== 'undefined') {\n payload['borderColor'] = borderColor;\n }\n\n if (typeof borderRadius !== 'undefined') {\n payload['borderRadius'] = borderRadius;\n }\n\n if (typeof opacity !== 'undefined') {\n payload['opacity'] = opacity;\n }\n\n if (typeof rotation !== 'undefined') {\n payload['rotation'] = rotation;\n }\n\n if (typeof background !== 'undefined') {\n payload['background'] = background;\n }\n\n if (typeof output !== 'undefined') {\n payload['output'] = output;\n }\n\n if (typeof token !== 'undefined') {\n payload['token'] = token;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * Get a file content by its unique ID. This endpoint is similar to the\n * download method but returns with no 'Content-Disposition: attachment'\n * header.\n *\n * @param {string} bucketId\n * @param {string} fileId\n * @param {string} token\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getFileViewURL(bucketId: string, fileId: string, token?: string): URL {\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}/view'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n if (typeof token !== 'undefined') {\n payload['token'] = token;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\n\nexport class TablesDB extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Get a list of all the user's rows in a given table. You can use the query params to filter your results.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID. You can create a new table using the TableDB service [server integration](https://appwrite.io/docs/server/tablesdbdb#tablesdbCreate).\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listRows<Row extends Models.Row = Models.DefaultRow>(params: { databaseId: string, tableId: string, queries?: string[] }): Promise<Models.RowList<Row>>;\n /**\n * Get a list of all the user's rows in a given table. You can use the query params to filter your results.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID. You can create a new table using the TableDB service [server integration](https://appwrite.io/docs/server/tablesdbdb#tablesdbCreate).\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise<Models.RowList<Row>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n listRows<Row extends Models.Row = Models.DefaultRow>(databaseId: string, tableId: string, queries?: string[]): Promise<Models.RowList<Row>>;\n listRows<Row extends Models.Row = Models.DefaultRow>(\n paramsOrFirst: { databaseId: string, tableId: string, queries?: string[] } | string,\n ...rest: [(string)?, (string[])?] \n ): Promise<Models.RowList<Row>> {\n let params: { databaseId: string, tableId: string, queries?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, queries?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n queries: rest[1] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const queries = params.queries;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows'.replace('{databaseId}', databaseId).replace('{tableId}', tableId);\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Create a new Row. Before using this route, you should create a new table resource using either a [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreateTable) API or directly from your database console.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID. You can create a new table using the Database service [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreate). Make sure to define columns before creating rows.\n * @param {string} params.rowId - Row ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>} params.data - Row data as JSON object.\n * @param {string[]} params.permissions - An array of permissions strings. By default, only the current user is granted all permissions. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createRow<Row extends Models.Row = Models.DefaultRow>(params: { databaseId: string, tableId: string, rowId: string, data: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>, permissions?: string[] }): Promise<Row>;\n /**\n * Create a new Row. Before using this route, you should create a new table resource using either a [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreateTable) API or directly from your database console.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID. You can create a new table using the Database service [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreate). Make sure to define columns before creating rows.\n * @param {string} rowId - Row ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>} data - Row data as JSON object.\n * @param {string[]} permissions - An array of permissions strings. By default, only the current user is granted all permissions. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Row>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createRow<Row extends Models.Row = Models.DefaultRow>(databaseId: string, tableId: string, rowId: string, data: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>, permissions?: string[]): Promise<Row>;\n createRow<Row extends Models.Row = Models.DefaultRow>(\n paramsOrFirst: { databaseId: string, tableId: string, rowId: string, data: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>, permissions?: string[] } | string,\n ...rest: [(string)?, (string)?, (Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>)?, (string[])?] \n ): Promise<Row> {\n let params: { databaseId: string, tableId: string, rowId: string, data: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>, permissions?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, rowId: string, data: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>, permissions?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n rowId: rest[1] as string,\n data: rest[2] as Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>,\n permissions: rest[3] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const rowId = params.rowId;\n const data = params.data;\n const permissions = params.permissions;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n if (typeof rowId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"rowId\"');\n }\n\n if (typeof data === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"data\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows'.replace('{databaseId}', databaseId).replace('{tableId}', tableId);\n const payload: Payload = {};\n\n if (typeof rowId !== 'undefined') {\n payload['rowId'] = rowId;\n }\n\n if (typeof data !== 'undefined') {\n payload['data'] = data;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get a row by its unique ID. This endpoint response returns a JSON object with the row data.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID. You can create a new table using the Database service [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreate).\n * @param {string} params.rowId - Row ID.\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getRow<Row extends Models.Row = Models.DefaultRow>(params: { databaseId: string, tableId: string, rowId: string, queries?: string[] }): Promise<Row>;\n /**\n * Get a row by its unique ID. This endpoint response returns a JSON object with the row data.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID. You can create a new table using the Database service [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreate).\n * @param {string} rowId - Row ID.\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise<Row>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getRow<Row extends Models.Row = Models.DefaultRow>(databaseId: string, tableId: string, rowId: string, queries?: string[]): Promise<Row>;\n getRow<Row extends Models.Row = Models.DefaultRow>(\n paramsOrFirst: { databaseId: string, tableId: string, rowId: string, queries?: string[] } | string,\n ...rest: [(string)?, (string)?, (string[])?] \n ): Promise<Row> {\n let params: { databaseId: string, tableId: string, rowId: string, queries?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, rowId: string, queries?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n rowId: rest[1] as string,\n queries: rest[2] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const rowId = params.rowId;\n const queries = params.queries;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n if (typeof rowId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"rowId\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows/{rowId}'.replace('{databaseId}', databaseId).replace('{tableId}', tableId).replace('{rowId}', rowId);\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Create or update a Row. Before using this route, you should create a new table resource using either a [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreateTable) API or directly from your database console.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID.\n * @param {string} params.rowId - Row ID.\n * @param {Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>} params.data - Row data as JSON object. Include all required columns of the row to be created or updated.\n * @param {string[]} params.permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n upsertRow<Row extends Models.Row = Models.DefaultRow>(params: { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] }): Promise<Row>;\n /**\n * Create or update a Row. Before using this route, you should create a new table resource using either a [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreateTable) API or directly from your database console.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID.\n * @param {string} rowId - Row ID.\n * @param {Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>} data - Row data as JSON object. Include all required columns of the row to be created or updated.\n * @param {string[]} permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Row>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n upsertRow<Row extends Models.Row = Models.DefaultRow>(databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[]): Promise<Row>;\n upsertRow<Row extends Models.Row = Models.DefaultRow>(\n paramsOrFirst: { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] } | string,\n ...rest: [(string)?, (string)?, (Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>)?, (string[])?] \n ): Promise<Row> {\n let params: { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n rowId: rest[1] as string,\n data: rest[2] as Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>,\n permissions: rest[3] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const rowId = params.rowId;\n const data = params.data;\n const permissions = params.permissions;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n if (typeof rowId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"rowId\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows/{rowId}'.replace('{databaseId}', databaseId).replace('{tableId}', tableId).replace('{rowId}', rowId);\n const payload: Payload = {};\n\n if (typeof data !== 'undefined') {\n payload['data'] = data;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Update a row by its unique ID. Using the patch method you can pass only specific fields that will get updated.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID.\n * @param {string} params.rowId - Row ID.\n * @param {Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>} params.data - Row data as JSON object. Include only columns and value pairs to be updated.\n * @param {string[]} params.permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateRow<Row extends Models.Row = Models.DefaultRow>(params: { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] }): Promise<Row>;\n /**\n * Update a row by its unique ID. Using the patch method you can pass only specific fields that will get updated.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID.\n * @param {string} rowId - Row ID.\n * @param {Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>} data - Row data as JSON object. Include only columns and value pairs to be updated.\n * @param {string[]} permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Row>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateRow<Row extends Models.Row = Models.DefaultRow>(databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[]): Promise<Row>;\n updateRow<Row extends Models.Row = Models.DefaultRow>(\n paramsOrFirst: { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] } | string,\n ...rest: [(string)?, (string)?, (Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>)?, (string[])?] \n ): Promise<Row> {\n let params: { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n rowId: rest[1] as string,\n data: rest[2] as Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>,\n permissions: rest[3] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const rowId = params.rowId;\n const data = params.data;\n const permissions = params.permissions;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n if (typeof rowId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"rowId\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows/{rowId}'.replace('{databaseId}', databaseId).replace('{tableId}', tableId).replace('{rowId}', rowId);\n const payload: Payload = {};\n\n if (typeof data !== 'undefined') {\n payload['data'] = data;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete a row by its unique ID.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID. You can create a new table using the Database service [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreate).\n * @param {string} params.rowId - Row ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteRow(params: { databaseId: string, tableId: string, rowId: string }): Promise<{}>;\n /**\n * Delete a row by its unique ID.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID. You can create a new table using the Database service [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreate).\n * @param {string} rowId - Row ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteRow(databaseId: string, tableId: string, rowId: string): Promise<{}>;\n deleteRow(\n paramsOrFirst: { databaseId: string, tableId: string, rowId: string } | string,\n ...rest: [(string)?, (string)?] \n ): Promise<{}> {\n let params: { databaseId: string, tableId: string, rowId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, rowId: string };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n rowId: rest[1] as string \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const rowId = params.rowId;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n if (typeof rowId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"rowId\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows/{rowId}'.replace('{databaseId}', databaseId).replace('{tableId}', tableId).replace('{rowId}', rowId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Decrement a specific column of a row by a given value.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID.\n * @param {string} params.rowId - Row ID.\n * @param {string} params.column - Column key.\n * @param {number} params.value - Value to increment the column by. The value must be a number.\n * @param {number} params.min - Minimum value for the column. If the current value is lesser than this value, an exception will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n decrementRowColumn<Row extends Models.Row = Models.DefaultRow>(params: { databaseId: string, tableId: string, rowId: string, column: string, value?: number, min?: number }): Promise<Row>;\n /**\n * Decrement a specific column of a row by a given value.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID.\n * @param {string} rowId - Row ID.\n * @param {string} column - Column key.\n * @param {number} value - Value to increment the column by. The value must be a number.\n * @param {number} min - Minimum value for the column. If the current value is lesser than this value, an exception will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise<Row>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n decrementRowColumn<Row extends Models.Row = Models.DefaultRow>(databaseId: string, tableId: string, rowId: string, column: string, value?: number, min?: number): Promise<Row>;\n decrementRowColumn<Row extends Models.Row = Models.DefaultRow>(\n paramsOrFirst: { databaseId: string, tableId: string, rowId: string, column: string, value?: number, min?: number } | string,\n ...rest: [(string)?, (string)?, (string)?, (number)?, (number)?] \n ): Promise<Row> {\n let params: { databaseId: string, tableId: string, rowId: string, column: string, value?: number, min?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, rowId: string, column: string, value?: number, min?: number };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n rowId: rest[1] as string,\n column: rest[2] as string,\n value: rest[3] as number,\n min: rest[4] as number \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const rowId = params.rowId;\n const column = params.column;\n const value = params.value;\n const min = params.min;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n if (typeof rowId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"rowId\"');\n }\n\n if (typeof column === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"column\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows/{rowId}/{column}/decrement'.replace('{databaseId}', databaseId).replace('{tableId}', tableId).replace('{rowId}', rowId).replace('{column}', column);\n const payload: Payload = {};\n\n if (typeof value !== 'undefined') {\n payload['value'] = value;\n }\n\n if (typeof min !== 'undefined') {\n payload['min'] = min;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Increment a specific column of a row by a given value.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID.\n * @param {string} params.rowId - Row ID.\n * @param {string} params.column - Column key.\n * @param {number} params.value - Value to increment the column by. The value must be a number.\n * @param {number} params.max - Maximum value for the column. If the current value is greater than this value, an error will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n incrementRowColumn<Row extends Models.Row = Models.DefaultRow>(params: { databaseId: string, tableId: string, rowId: string, column: string, value?: number, max?: number }): Promise<Row>;\n /**\n * Increment a specific column of a row by a given value.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID.\n * @param {string} rowId - Row ID.\n * @param {string} column - Column key.\n * @param {number} value - Value to increment the column by. The value must be a number.\n * @param {number} max - Maximum value for the column. If the current value is greater than this value, an error will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise<Row>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n incrementRowColumn<Row extends Models.Row = Models.DefaultRow>(databaseId: string, tableId: string, rowId: string, column: string, value?: number, max?: number): Promise<Row>;\n incrementRowColumn<Row extends Models.Row = Models.DefaultRow>(\n paramsOrFirst: { databaseId: string, tableId: string, rowId: string, column: string, value?: number, max?: number } | string,\n ...rest: [(string)?, (string)?, (string)?, (number)?, (number)?] \n ): Promise<Row> {\n let params: { databaseId: string, tableId: string, rowId: string, column: string, value?: number, max?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, rowId: string, column: string, value?: number, max?: number };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n rowId: rest[1] as string,\n column: rest[2] as string,\n value: rest[3] as number,\n max: rest[4] as number \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const rowId = params.rowId;\n const column = params.column;\n const value = params.value;\n const max = params.max;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n if (typeof rowId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"rowId\"');\n }\n\n if (typeof column === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"column\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows/{rowId}/{column}/increment'.replace('{databaseId}', databaseId).replace('{tableId}', tableId).replace('{rowId}', rowId).replace('{column}', column);\n const payload: Payload = {};\n\n if (typeof value !== 'undefined') {\n payload['value'] = value;\n }\n\n if (typeof max !== 'undefined') {\n payload['max'] = max;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\n\nexport class Teams extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Get a list of all the teams in which the current user is a member. You can use the parameters to filter your results.\n *\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: name, total, billingPlan\n * @param {string} params.search - Search term to filter your list results. Max length: 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n list<Preferences extends Models.Preferences = Models.DefaultPreferences>(params?: { queries?: string[], search?: string }): Promise<Models.TeamList<Preferences>>;\n /**\n * Get a list of all the teams in which the current user is a member. You can use the parameters to filter your results.\n *\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: name, total, billingPlan\n * @param {string} search - Search term to filter your list results. Max length: 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.TeamList<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n list<Preferences extends Models.Preferences = Models.DefaultPreferences>(queries?: string[], search?: string): Promise<Models.TeamList<Preferences>>;\n list<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst?: { queries?: string[], search?: string } | string[],\n ...rest: [(string)?] \n ): Promise<Models.TeamList<Preferences>> {\n let params: { queries?: string[], search?: string };\n\n if (!paramsOrFirst || (paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { queries?: string[], search?: string };\n } else {\n params = {\n queries: paramsOrFirst as string[],\n search: rest[0] as string \n };\n }\n\n const queries = params.queries;\n const search = params.search;\n\n const apiPath = '/teams';\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n if (typeof search !== 'undefined') {\n payload['search'] = search;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Create a new team. The user who creates the team will automatically be assigned as the owner of the team. Only the users with the owner role can invite new members, add new owners and delete or update the team.\n *\n * @param {string} params.teamId - Team ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} params.name - Team name. Max length: 128 chars.\n * @param {string[]} params.roles - Array of strings. Use this param to set the roles in the team for the user who created it. The default role is **owner**. A role can be any string. Learn more about [roles and permissions](https://appwrite.io/docs/permissions). Maximum of 100 roles are allowed, each 32 characters long.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n create<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { teamId: string, name: string, roles?: string[] }): Promise<Models.Team<Preferences>>;\n /**\n * Create a new team. The user who creates the team will automatically be assigned as the owner of the team. Only the users with the owner role can invite new members, add new owners and delete or update the team.\n *\n * @param {string} teamId - Team ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} name - Team name. Max length: 128 chars.\n * @param {string[]} roles - Array of strings. Use this param to set the roles in the team for the user who created it. The default role is **owner**. A role can be any string. Learn more about [roles and permissions](https://appwrite.io/docs/permissions). Maximum of 100 roles are allowed, each 32 characters long.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Team<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n create<Preferences extends Models.Preferences = Models.DefaultPreferences>(teamId: string, name: string, roles?: string[]): Promise<Models.Team<Preferences>>;\n create<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { teamId: string, name: string, roles?: string[] } | string,\n ...rest: [(string)?, (string[])?] \n ): Promise<Models.Team<Preferences>> {\n let params: { teamId: string, name: string, roles?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, name: string, roles?: string[] };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n name: rest[0] as string,\n roles: rest[1] as string[] \n };\n }\n\n const teamId = params.teamId;\n const name = params.name;\n const roles = params.roles;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof name === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"name\"');\n }\n\n const apiPath = '/teams';\n const payload: Payload = {};\n\n if (typeof teamId !== 'undefined') {\n payload['teamId'] = teamId;\n }\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n if (typeof roles !== 'undefined') {\n payload['roles'] = roles;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get a team by its ID. All team members have read access for this resource.\n *\n * @param {string} params.teamId - Team ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n get<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { teamId: string }): Promise<Models.Team<Preferences>>;\n /**\n * Get a team by its ID. All team members have read access for this resource.\n *\n * @param {string} teamId - Team ID.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Team<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n get<Preferences extends Models.Preferences = Models.DefaultPreferences>(teamId: string): Promise<Models.Team<Preferences>>;\n get<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { teamId: string } | string \n ): Promise<Models.Team<Preferences>> {\n let params: { teamId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string };\n } else {\n params = {\n teamId: paramsOrFirst as string \n };\n }\n\n const teamId = params.teamId;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n const apiPath = '/teams/{teamId}'.replace('{teamId}', teamId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Update the team's name by its unique ID.\n *\n * @param {string} params.teamId - Team ID.\n * @param {string} params.name - New team name. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateName<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { teamId: string, name: string }): Promise<Models.Team<Preferences>>;\n /**\n * Update the team's name by its unique ID.\n *\n * @param {string} teamId - Team ID.\n * @param {string} name - New team name. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Team<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateName<Preferences extends Models.Preferences = Models.DefaultPreferences>(teamId: string, name: string): Promise<Models.Team<Preferences>>;\n updateName<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { teamId: string, name: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Team<Preferences>> {\n let params: { teamId: string, name: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, name: string };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n name: rest[0] as string \n };\n }\n\n const teamId = params.teamId;\n const name = params.name;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof name === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"name\"');\n }\n\n const apiPath = '/teams/{teamId}'.replace('{teamId}', teamId);\n const payload: Payload = {};\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete a team using its ID. Only team members with the owner role can delete the team.\n *\n * @param {string} params.teamId - Team ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n delete(params: { teamId: string }): Promise<{}>;\n /**\n * Delete a team using its ID. Only team members with the owner role can delete the team.\n *\n * @param {string} teamId - Team ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n delete(teamId: string): Promise<{}>;\n delete(\n paramsOrFirst: { teamId: string } | string \n ): Promise<{}> {\n let params: { teamId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string };\n } else {\n params = {\n teamId: paramsOrFirst as string \n };\n }\n\n const teamId = params.teamId;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n const apiPath = '/teams/{teamId}'.replace('{teamId}', teamId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to list a team's members using the team's ID. All team members have read access to this endpoint. Hide sensitive attributes from the response by toggling membership privacy in the Console.\n *\n * @param {string} params.teamId - Team ID.\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: userId, teamId, invited, joined, confirm, roles\n * @param {string} params.search - Search term to filter your list results. Max length: 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listMemberships(params: { teamId: string, queries?: string[], search?: string }): Promise<Models.MembershipList>;\n /**\n * Use this endpoint to list a team's members using the team's ID. All team members have read access to this endpoint. Hide sensitive attributes from the response by toggling membership privacy in the Console.\n *\n * @param {string} teamId - Team ID.\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: userId, teamId, invited, joined, confirm, roles\n * @param {string} search - Search term to filter your list results. Max length: 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.MembershipList>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n listMemberships(teamId: string, queries?: string[], search?: string): Promise<Models.MembershipList>;\n listMemberships(\n paramsOrFirst: { teamId: string, queries?: string[], search?: string } | string,\n ...rest: [(string[])?, (string)?] \n ): Promise<Models.MembershipList> {\n let params: { teamId: string, queries?: string[], search?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, queries?: string[], search?: string };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n queries: rest[0] as string[],\n search: rest[1] as string \n };\n }\n\n const teamId = params.teamId;\n const queries = params.queries;\n const search = params.search;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n const apiPath = '/teams/{teamId}/memberships'.replace('{teamId}', teamId);\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n if (typeof search !== 'undefined') {\n payload['search'] = search;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Invite a new member to join your team. Provide an ID for existing users, or invite unregistered users using an email or phone number. If initiated from a Client SDK, Appwrite will send an email or sms with a link to join the team to the invited user, and an account will be created for them if one doesn't exist. If initiated from a Server SDK, the new member will be added automatically to the team.\n * \n * You only need to provide one of a user ID, email, or phone number. Appwrite will prioritize accepting the user ID > email > phone number if you provide more than one of these parameters.\n * \n * Use the `url` parameter to redirect the user from the invitation email to your app. After the user is redirected, use the [Update Team Membership Status](https://appwrite.io/docs/references/cloud/client-web/teams#updateMembershipStatus) endpoint to allow the user to accept the invitation to the team. \n * \n * Please note that to avoid a [Redirect Attack](https://github.com/OWASP/CheatSheetSeries/blob/master/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.md) Appwrite will accept the only redirect URLs under the domains you have added as a platform on the Appwrite Console.\n * \n *\n * @param {string} params.teamId - Team ID.\n * @param {string[]} params.roles - Array of strings. Use this param to set the user roles in the team. A role can be any string. Learn more about [roles and permissions](https://appwrite.io/docs/permissions). Maximum of 100 roles are allowed, each 32 characters long.\n * @param {string} params.email - Email of the new team member.\n * @param {string} params.userId - ID of the user to be added to a team.\n * @param {string} params.phone - Phone number. Format this number with a leading '+' and a country code, e.g., +16175551212.\n * @param {string} params.url - URL to redirect the user back to your app from the invitation email. This parameter is not required when an API key is supplied. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string} params.name - Name of the new team member. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createMembership(params: { teamId: string, roles: string[], email?: string, userId?: string, phone?: string, url?: string, name?: string }): Promise<Models.Membership>;\n /**\n * Invite a new member to join your team. Provide an ID for existing users, or invite unregistered users using an email or phone number. If initiated from a Client SDK, Appwrite will send an email or sms with a link to join the team to the invited user, and an account will be created for them if one doesn't exist. If initiated from a Server SDK, the new member will be added automatically to the team.\n * \n * You only need to provide one of a user ID, email, or phone number. Appwrite will prioritize accepting the user ID > email > phone number if you provide more than one of these parameters.\n * \n * Use the `url` parameter to redirect the user from the invitation email to your app. After the user is redirected, use the [Update Team Membership Status](https://appwrite.io/docs/references/cloud/client-web/teams#updateMembershipStatus) endpoint to allow the user to accept the invitation to the team. \n * \n * Please note that to avoid a [Redirect Attack](https://github.com/OWASP/CheatSheetSeries/blob/master/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.md) Appwrite will accept the only redirect URLs under the domains you have added as a platform on the Appwrite Console.\n * \n *\n * @param {string} teamId - Team ID.\n * @param {string[]} roles - Array of strings. Use this param to set the user roles in the team. A role can be any string. Learn more about [roles and permissions](https://appwrite.io/docs/permissions). Maximum of 100 roles are allowed, each 32 characters long.\n * @param {string} email - Email of the new team member.\n * @param {string} userId - ID of the user to be added to a team.\n * @param {string} phone - Phone number. Format this number with a leading '+' and a country code, e.g., +16175551212.\n * @param {string} url - URL to redirect the user back to your app from the invitation email. This parameter is not required when an API key is supplied. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string} name - Name of the new team member. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Membership>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createMembership(teamId: string, roles: string[], email?: string, userId?: string, phone?: string, url?: string, name?: string): Promise<Models.Membership>;\n createMembership(\n paramsOrFirst: { teamId: string, roles: string[], email?: string, userId?: string, phone?: string, url?: string, name?: string } | string,\n ...rest: [(string[])?, (string)?, (string)?, (string)?, (string)?, (string)?] \n ): Promise<Models.Membership> {\n let params: { teamId: string, roles: string[], email?: string, userId?: string, phone?: string, url?: string, name?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, roles: string[], email?: string, userId?: string, phone?: string, url?: string, name?: string };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n roles: rest[0] as string[],\n email: rest[1] as string,\n userId: rest[2] as string,\n phone: rest[3] as string,\n url: rest[4] as string,\n name: rest[5] as string \n };\n }\n\n const teamId = params.teamId;\n const roles = params.roles;\n const email = params.email;\n const userId = params.userId;\n const phone = params.phone;\n const url = params.url;\n const name = params.name;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof roles === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"roles\"');\n }\n\n const apiPath = '/teams/{teamId}/memberships'.replace('{teamId}', teamId);\n const payload: Payload = {};\n\n if (typeof email !== 'undefined') {\n payload['email'] = email;\n }\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof phone !== 'undefined') {\n payload['phone'] = phone;\n }\n\n if (typeof roles !== 'undefined') {\n payload['roles'] = roles;\n }\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get a team member by the membership unique id. All team members have read access for this resource. Hide sensitive attributes from the response by toggling membership privacy in the Console.\n *\n * @param {string} params.teamId - Team ID.\n * @param {string} params.membershipId - Membership ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getMembership(params: { teamId: string, membershipId: string }): Promise<Models.Membership>;\n /**\n * Get a team member by the membership unique id. All team members have read access for this resource. Hide sensitive attributes from the response by toggling membership privacy in the Console.\n *\n * @param {string} teamId - Team ID.\n * @param {string} membershipId - Membership ID.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Membership>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getMembership(teamId: string, membershipId: string): Promise<Models.Membership>;\n getMembership(\n paramsOrFirst: { teamId: string, membershipId: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Membership> {\n let params: { teamId: string, membershipId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, membershipId: string };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n membershipId: rest[0] as string \n };\n }\n\n const teamId = params.teamId;\n const membershipId = params.membershipId;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof membershipId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"membershipId\"');\n }\n\n const apiPath = '/teams/{teamId}/memberships/{membershipId}'.replace('{teamId}', teamId).replace('{membershipId}', membershipId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Modify the roles of a team member. Only team members with the owner role have access to this endpoint. Learn more about [roles and permissions](https://appwrite.io/docs/permissions).\n * \n *\n * @param {string} params.teamId - Team ID.\n * @param {string} params.membershipId - Membership ID.\n * @param {string[]} params.roles - An array of strings. Use this param to set the user's roles in the team. A role can be any string. Learn more about [roles and permissions](https://appwrite.io/docs/permissions). Maximum of 100 roles are allowed, each 32 characters long.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateMembership(params: { teamId: string, membershipId: string, roles: string[] }): Promise<Models.Membership>;\n /**\n * Modify the roles of a team member. Only team members with the owner role have access to this endpoint. Learn more about [roles and permissions](https://appwrite.io/docs/permissions).\n * \n *\n * @param {string} teamId - Team ID.\n * @param {string} membershipId - Membership ID.\n * @param {string[]} roles - An array of strings. Use this param to set the user's roles in the team. A role can be any string. Learn more about [roles and permissions](https://appwrite.io/docs/permissions). Maximum of 100 roles are allowed, each 32 characters long.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Membership>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMembership(teamId: string, membershipId: string, roles: string[]): Promise<Models.Membership>;\n updateMembership(\n paramsOrFirst: { teamId: string, membershipId: string, roles: string[] } | string,\n ...rest: [(string)?, (string[])?] \n ): Promise<Models.Membership> {\n let params: { teamId: string, membershipId: string, roles: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, membershipId: string, roles: string[] };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n membershipId: rest[0] as string,\n roles: rest[1] as string[] \n };\n }\n\n const teamId = params.teamId;\n const membershipId = params.membershipId;\n const roles = params.roles;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof membershipId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"membershipId\"');\n }\n\n if (typeof roles === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"roles\"');\n }\n\n const apiPath = '/teams/{teamId}/memberships/{membershipId}'.replace('{teamId}', teamId).replace('{membershipId}', membershipId);\n const payload: Payload = {};\n\n if (typeof roles !== 'undefined') {\n payload['roles'] = roles;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * This endpoint allows a user to leave a team or for a team owner to delete the membership of any other team member. You can also use this endpoint to delete a user membership even if it is not accepted.\n *\n * @param {string} params.teamId - Team ID.\n * @param {string} params.membershipId - Membership ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteMembership(params: { teamId: string, membershipId: string }): Promise<{}>;\n /**\n * This endpoint allows a user to leave a team or for a team owner to delete the membership of any other team member. You can also use this endpoint to delete a user membership even if it is not accepted.\n *\n * @param {string} teamId - Team ID.\n * @param {string} membershipId - Membership ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteMembership(teamId: string, membershipId: string): Promise<{}>;\n deleteMembership(\n paramsOrFirst: { teamId: string, membershipId: string } | string,\n ...rest: [(string)?] \n ): Promise<{}> {\n let params: { teamId: string, membershipId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, membershipId: string };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n membershipId: rest[0] as string \n };\n }\n\n const teamId = params.teamId;\n const membershipId = params.membershipId;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof membershipId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"membershipId\"');\n }\n\n const apiPath = '/teams/{teamId}/memberships/{membershipId}'.replace('{teamId}', teamId).replace('{membershipId}', membershipId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to allow a user to accept an invitation to join a team after being redirected back to your app from the invitation email received by the user.\n * \n * If the request is successful, a session for the user is automatically created.\n * \n *\n * @param {string} params.teamId - Team ID.\n * @param {string} params.membershipId - Membership ID.\n * @param {string} params.userId - User ID.\n * @param {string} params.secret - Secret key.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateMembershipStatus(params: { teamId: string, membershipId: string, userId: string, secret: string }): Promise<Models.Membership>;\n /**\n * Use this endpoint to allow a user to accept an invitation to join a team after being redirected back to your app from the invitation email received by the user.\n * \n * If the request is successful, a session for the user is automatically created.\n * \n *\n * @param {string} teamId - Team ID.\n * @param {string} membershipId - Membership ID.\n * @param {string} userId - User ID.\n * @param {string} secret - Secret key.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Membership>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMembershipStatus(teamId: string, membershipId: string, userId: string, secret: string): Promise<Models.Membership>;\n updateMembershipStatus(\n paramsOrFirst: { teamId: string, membershipId: string, userId: string, secret: string } | string,\n ...rest: [(string)?, (string)?, (string)?] \n ): Promise<Models.Membership> {\n let params: { teamId: string, membershipId: string, userId: string, secret: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, membershipId: string, userId: string, secret: string };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n membershipId: rest[0] as string,\n userId: rest[1] as string,\n secret: rest[2] as string \n };\n }\n\n const teamId = params.teamId;\n const membershipId = params.membershipId;\n const userId = params.userId;\n const secret = params.secret;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof membershipId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"membershipId\"');\n }\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof secret === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"secret\"');\n }\n\n const apiPath = '/teams/{teamId}/memberships/{membershipId}/status'.replace('{teamId}', teamId).replace('{membershipId}', membershipId);\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof secret !== 'undefined') {\n payload['secret'] = secret;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get the team's shared preferences by its unique ID. If a preference doesn't need to be shared by all team members, prefer storing them in [user preferences](https://appwrite.io/docs/references/cloud/client-web/account#getPrefs).\n *\n * @param {string} params.teamId - Team ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getPrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { teamId: string }): Promise<Preferences>;\n /**\n * Get the team's shared preferences by its unique ID. If a preference doesn't need to be shared by all team members, prefer storing them in [user preferences](https://appwrite.io/docs/references/cloud/client-web/account#getPrefs).\n *\n * @param {string} teamId - Team ID.\n * @throws {AppwriteException}\n * @returns {Promise<Preferences>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getPrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(teamId: string): Promise<Preferences>;\n getPrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { teamId: string } | string \n ): Promise<Preferences> {\n let params: { teamId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string };\n } else {\n params = {\n teamId: paramsOrFirst as string \n };\n }\n\n const teamId = params.teamId;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n const apiPath = '/teams/{teamId}/prefs'.replace('{teamId}', teamId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Update the team's preferences by its unique ID. The object you pass is stored as is and replaces any previous value. The maximum allowed prefs size is 64kB and throws an error if exceeded.\n *\n * @param {string} params.teamId - Team ID.\n * @param {object} params.prefs - Prefs key-value JSON object.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updatePrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { teamId: string, prefs: object }): Promise<Preferences>;\n /**\n * Update the team's preferences by its unique ID. The object you pass is stored as is and replaces any previous value. The maximum allowed prefs size is 64kB and throws an error if exceeded.\n *\n * @param {string} teamId - Team ID.\n * @param {object} prefs - Prefs key-value JSON object.\n * @throws {AppwriteException}\n * @returns {Promise<Preferences>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updatePrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(teamId: string, prefs: object): Promise<Preferences>;\n updatePrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { teamId: string, prefs: object } | string,\n ...rest: [(object)?] \n ): Promise<Preferences> {\n let params: { teamId: string, prefs: object };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, prefs: object };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n prefs: rest[0] as object \n };\n }\n\n const teamId = params.teamId;\n const prefs = params.prefs;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof prefs === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"prefs\"');\n }\n\n const apiPath = '/teams/{teamId}/prefs'.replace('{teamId}', teamId);\n const payload: Payload = {};\n\n if (typeof prefs !== 'undefined') {\n payload['prefs'] = prefs;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n};\n","type QueryTypesSingle = string | number | boolean;\nexport type QueryTypesList = string[] | number[] | boolean[] | Query[] | any[];\nexport type QueryTypes = QueryTypesSingle | QueryTypesList;\ntype AttributesTypes = string | string[];\n\nexport class Query {\n method: string;\n attribute: AttributesTypes | undefined;\n values: QueryTypesList | undefined;\n\n constructor(\n method: string,\n attribute?: AttributesTypes,\n values?: QueryTypes\n ) {\n this.method = method;\n this.attribute = attribute;\n\n if (values !== undefined) {\n if (Array.isArray(values)) {\n this.values = values;\n } else {\n this.values = [values] as QueryTypesList;\n }\n }\n }\n\n toString(): string {\n return JSON.stringify({\n method: this.method,\n attribute: this.attribute,\n values: this.values,\n });\n }\n\n static equal = (attribute: string, value: QueryTypes): string =>\n new Query(\"equal\", attribute, value).toString();\n\n static notEqual = (attribute: string, value: QueryTypes): string =>\n new Query(\"notEqual\", attribute, value).toString();\n\n static lessThan = (attribute: string, value: QueryTypes): string =>\n new Query(\"lessThan\", attribute, value).toString();\n\n static lessThanEqual = (attribute: string, value: QueryTypes): string =>\n new Query(\"lessThanEqual\", attribute, value).toString();\n\n static greaterThan = (attribute: string, value: QueryTypes): string =>\n new Query(\"greaterThan\", attribute, value).toString();\n\n static greaterThanEqual = (attribute: string, value: QueryTypes): string =>\n new Query(\"greaterThanEqual\", attribute, value).toString();\n\n static isNull = (attribute: string): string =>\n new Query(\"isNull\", attribute).toString();\n\n static isNotNull = (attribute: string): string =>\n new Query(\"isNotNull\", attribute).toString();\n\n static between = (attribute: string, start: string | number, end: string | number) =>\n new Query(\"between\", attribute, [start, end] as QueryTypesList).toString();\n\n static startsWith = (attribute: string, value: string): string =>\n new Query(\"startsWith\", attribute, value).toString();\n\n static endsWith = (attribute: string, value: string): string =>\n new Query(\"endsWith\", attribute, value).toString();\n\n static select = (attributes: string[]): string =>\n new Query(\"select\", undefined, attributes).toString();\n\n static search = (attribute: string, value: string): string =>\n new Query(\"search\", attribute, value).toString();\n\n static orderDesc = (attribute: string): string =>\n new Query(\"orderDesc\", attribute).toString();\n\n static orderAsc = (attribute: string): string =>\n new Query(\"orderAsc\", attribute).toString();\n\n static orderRandom = (): string =>\n new Query(\"orderRandom\").toString();\n\n static cursorAfter = (documentId: string): string =>\n new Query(\"cursorAfter\", undefined, documentId).toString();\n\n static cursorBefore = (documentId: string): string =>\n new Query(\"cursorBefore\", undefined, documentId).toString();\n\n static limit = (limit: number): string =>\n new Query(\"limit\", undefined, limit).toString();\n\n static offset = (offset: number): string =>\n new Query(\"offset\", undefined, offset).toString();\n\n /**\n * Filter resources where attribute contains the specified value.\n *\n * @param {string} attribute\n * @param {string | string[]} value\n * @returns {string}\n */\n static contains = (attribute: string, value: string | any[]): string =>\n new Query(\"contains\", attribute, value).toString();\n\n /**\n * Filter resources where attribute does not contain the specified value.\n *\n * @param {string} attribute\n * @param {string | string[]} value\n * @returns {string}\n */\n static notContains = (attribute: string, value: string | any[]): string =>\n new Query(\"notContains\", attribute, value).toString();\n\n /**\n * Filter resources by searching attribute for value (inverse of search).\n * A fulltext index on attribute is required for this query to work.\n *\n * @param {string} attribute\n * @param {string} value\n * @returns {string}\n */\n static notSearch = (attribute: string, value: string): string =>\n new Query(\"notSearch\", attribute, value).toString();\n\n /**\n * Filter resources where attribute is not between start and end (exclusive).\n *\n * @param {string} attribute\n * @param {string | number} start\n * @param {string | number} end\n * @returns {string}\n */\n static notBetween = (attribute: string, start: string | number, end: string | number): string =>\n new Query(\"notBetween\", attribute, [start, end] as QueryTypesList).toString();\n\n /**\n * Filter resources where attribute does not start with value.\n *\n * @param {string} attribute\n * @param {string} value\n * @returns {string}\n */\n static notStartsWith = (attribute: string, value: string): string =>\n new Query(\"notStartsWith\", attribute, value).toString();\n\n /**\n * Filter resources where attribute does not end with value.\n *\n * @param {string} attribute\n * @param {string} value\n * @returns {string}\n */\n static notEndsWith = (attribute: string, value: string): string =>\n new Query(\"notEndsWith\", attribute, value).toString();\n\n /**\n * Filter resources where document was created before date.\n *\n * @param {string} value\n * @returns {string}\n */\n static createdBefore = (value: string): string =>\n new Query(\"createdBefore\", undefined, value).toString();\n\n /**\n * Filter resources where document was created after date.\n *\n * @param {string} value\n * @returns {string}\n */\n static createdAfter = (value: string): string =>\n new Query(\"createdAfter\", undefined, value).toString();\n\n /**\n * Filter resources where document was created between dates.\n *\n * @param {string} start\n * @param {string} end\n * @returns {string}\n */\n static createdBetween = (start: string, end: string): string =>\n new Query(\"createdBetween\", undefined, [start, end] as QueryTypesList).toString();\n\n /**\n * Filter resources where document was updated before date.\n *\n * @param {string} value\n * @returns {string}\n */\n static updatedBefore = (value: string): string =>\n new Query(\"updatedBefore\", undefined, value).toString();\n\n /**\n * Filter resources where document was updated after date.\n *\n * @param {string} value\n * @returns {string}\n */\n static updatedAfter = (value: string): string =>\n new Query(\"updatedAfter\", undefined, value).toString();\n\n /**\n * Filter resources where document was updated between dates.\n *\n * @param {string} start\n * @param {string} end\n * @returns {string}\n */\n static updatedBetween = (start: string, end: string): string =>\n new Query(\"updatedBetween\", undefined, [start, end] as QueryTypesList).toString();\n\n static or = (queries: string[]) =>\n new Query(\"or\", undefined, queries.map((query) => JSON.parse(query))).toString();\n\n static and = (queries: string[]) =>\n new Query(\"and\", undefined, queries.map((query) => JSON.parse(query))).toString();\n\n /**\n * Filter resources where attribute is at a specific distance from the given coordinates.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @param {number} distance\n * @param {boolean} meters\n * @returns {string}\n */\n static distanceEqual = (attribute: string, values: any[], distance: number, meters: boolean = true): string =>\n new Query(\"distanceEqual\", attribute, [[values, distance, meters]] as QueryTypesList).toString();\n\n /**\n * Filter resources where attribute is not at a specific distance from the given coordinates.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @param {number} distance\n * @param {boolean} meters\n * @returns {string}\n */\n static distanceNotEqual = (attribute: string, values: any[], distance: number, meters: boolean = true): string =>\n new Query(\"distanceNotEqual\", attribute, [[values, distance, meters]] as QueryTypesList).toString();\n\n /**\n * Filter resources where attribute is at a distance greater than the specified value from the given coordinates.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @param {number} distance\n * @param {boolean} meters\n * @returns {string}\n */\n static distanceGreaterThan = (attribute: string, values: any[], distance: number, meters: boolean = true): string =>\n new Query(\"distanceGreaterThan\", attribute, [[values, distance, meters]] as QueryTypesList).toString();\n\n /**\n * Filter resources where attribute is at a distance less than the specified value from the given coordinates.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @param {number} distance\n * @param {boolean} meters\n * @returns {string}\n */\n static distanceLessThan = (attribute: string, values: any[], distance: number, meters: boolean = true): string =>\n new Query(\"distanceLessThan\", attribute, [[values, distance, meters]] as QueryTypesList).toString();\n\n /**\n * Filter resources where attribute intersects with the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static intersects = (attribute: string, values: any[]): string =>\n new Query(\"intersects\", attribute, [values]).toString();\n\n /**\n * Filter resources where attribute does not intersect with the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static notIntersects = (attribute: string, values: any[]): string =>\n new Query(\"notIntersects\", attribute, [values]).toString();\n\n /**\n * Filter resources where attribute crosses the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static crosses = (attribute: string, values: any[]): string =>\n new Query(\"crosses\", attribute, [values]).toString();\n\n /**\n * Filter resources where attribute does not cross the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static notCrosses = (attribute: string, values: any[]): string =>\n new Query(\"notCrosses\", attribute, [values]).toString();\n\n /**\n * Filter resources where attribute overlaps with the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static overlaps = (attribute: string, values: any[]): string =>\n new Query(\"overlaps\", attribute, [values]).toString();\n\n /**\n * Filter resources where attribute does not overlap with the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static notOverlaps = (attribute: string, values: any[]): string =>\n new Query(\"notOverlaps\", attribute, [values]).toString();\n\n /**\n * Filter resources where attribute touches the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static touches = (attribute: string, values: any[]): string =>\n new Query(\"touches\", attribute, [values]).toString();\n\n /**\n * Filter resources where attribute does not touch the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static notTouches = (attribute: string, values: any[]): string =>\n new Query(\"notTouches\", attribute, [values]).toString();\n}\n","export class Permission {\n\n static read = (role: string): string => {\n return `read(\"${role}\")`\n }\n\n static write = (role: string): string => {\n return `write(\"${role}\")`\n }\n\n static create = (role: string): string => {\n return `create(\"${role}\")`\n }\n\n static update = (role: string): string => {\n return `update(\"${role}\")`\n }\n\n static delete = (role: string): string => {\n return `delete(\"${role}\")`\n }\n}\n","/**\n * Helper class to generate role strings for `Permission`.\n */\nexport class Role {\n\n /**\n * Grants access to anyone.\n * \n * This includes authenticated and unauthenticated users.\n * \n * @returns {string}\n */\n public static any(): string {\n return 'any'\n }\n\n /**\n * Grants access to a specific user by user ID.\n * \n * You can optionally pass verified or unverified for\n * `status` to target specific types of users.\n *\n * @param {string} id \n * @param {string} status \n * @returns {string}\n */\n public static user(id: string, status: string = ''): string {\n if (status === '') {\n return `user:${id}`\n }\n return `user:${id}/${status}`\n }\n\n /**\n * Grants access to any authenticated or anonymous user.\n * \n * You can optionally pass verified or unverified for\n * `status` to target specific types of users.\n * \n * @param {string} status \n * @returns {string}\n */\n public static users(status: string = ''): string {\n if (status === '') {\n return 'users'\n }\n return `users/${status}`\n }\n\n /**\n * Grants access to any guest user without a session.\n * \n * Authenticated users don't have access to this role.\n * \n * @returns {string}\n */\n public static guests(): string {\n return 'guests'\n }\n\n /**\n * Grants access to a team by team ID.\n * \n * You can optionally pass a role for `role` to target\n * team members with the specified role.\n * \n * @param {string} id \n * @param {string} role \n * @returns {string}\n */\n public static team(id: string, role: string = ''): string {\n if (role === '') {\n return `team:${id}`\n }\n return `team:${id}/${role}`\n }\n\n /**\n * Grants access to a specific member of a team.\n * \n * When the member is removed from the team, they will\n * no longer have access.\n * \n * @param {string} id \n * @returns {string}\n */\n public static member(id: string): string {\n return `member:${id}`\n }\n\n /**\n * Grants access to a user with the specified label.\n * \n * @param {string} name \n * @returns {string}\n */\n public static label(name: string): string {\n return `label:${name}`\n }\n}","export class ID {\n // Generate an hex ID based on timestamp\n // Recreated from https://www.php.net/manual/en/function.uniqid.php\n static #hexTimestamp(): string {\n const now = new Date();\n const sec = Math.floor(now.getTime() / 1000);\n const msec = now.getMilliseconds();\n\n // Convert to hexadecimal\n const hexTimestamp = sec.toString(16) + msec.toString(16).padStart(5, '0');\n return hexTimestamp;\n }\n\n public static custom(id: string): string {\n return id\n }\n\n public static unique(padding: number = 7): string {\n // Generate a unique ID with padding to have a longer ID\n const baseId = ID.#hexTimestamp();\n let randomPadding = '';\n for (let i = 0; i < padding; i++) {\n const randomHexDigit = Math.floor(Math.random() * 16).toString(16);\n randomPadding += randomHexDigit;\n }\n return baseId + randomPadding;\n }\n}\n","export enum AuthenticatorType {\n Totp = 'totp',\n}","export enum AuthenticationFactor {\n Email = 'email',\n Phone = 'phone',\n Totp = 'totp',\n Recoverycode = 'recoverycode',\n}","export enum OAuthProvider {\n Amazon = 'amazon',\n Apple = 'apple',\n Auth0 = 'auth0',\n Authentik = 'authentik',\n Autodesk = 'autodesk',\n Bitbucket = 'bitbucket',\n Bitly = 'bitly',\n Box = 'box',\n Dailymotion = 'dailymotion',\n Discord = 'discord',\n Disqus = 'disqus',\n Dropbox = 'dropbox',\n Etsy = 'etsy',\n Facebook = 'facebook',\n Figma = 'figma',\n Github = 'github',\n Gitlab = 'gitlab',\n Google = 'google',\n Linkedin = 'linkedin',\n Microsoft = 'microsoft',\n Notion = 'notion',\n Oidc = 'oidc',\n Okta = 'okta',\n Paypal = 'paypal',\n PaypalSandbox = 'paypalSandbox',\n Podio = 'podio',\n Salesforce = 'salesforce',\n Slack = 'slack',\n Spotify = 'spotify',\n Stripe = 'stripe',\n Tradeshift = 'tradeshift',\n TradeshiftBox = 'tradeshiftBox',\n Twitch = 'twitch',\n Wordpress = 'wordpress',\n Yahoo = 'yahoo',\n Yammer = 'yammer',\n Yandex = 'yandex',\n Zoho = 'zoho',\n Zoom = 'zoom',\n Mock = 'mock',\n}","export enum Browser {\n AvantBrowser = 'aa',\n AndroidWebViewBeta = 'an',\n GoogleChrome = 'ch',\n GoogleChromeIOS = 'ci',\n GoogleChromeMobile = 'cm',\n Chromium = 'cr',\n MozillaFirefox = 'ff',\n Safari = 'sf',\n MobileSafari = 'mf',\n MicrosoftEdge = 'ps',\n MicrosoftEdgeIOS = 'oi',\n OperaMini = 'om',\n Opera = 'op',\n OperaNext = 'on',\n}","export enum CreditCard {\n AmericanExpress = 'amex',\n Argencard = 'argencard',\n Cabal = 'cabal',\n Cencosud = 'cencosud',\n DinersClub = 'diners',\n Discover = 'discover',\n Elo = 'elo',\n Hipercard = 'hipercard',\n JCB = 'jcb',\n Mastercard = 'mastercard',\n Naranja = 'naranja',\n TarjetaShopping = 'targeta-shopping',\n UnionPay = 'unionpay',\n Visa = 'visa',\n MIR = 'mir',\n Maestro = 'maestro',\n Rupay = 'rupay',\n}","export enum Flag {\n Afghanistan = 'af',\n Angola = 'ao',\n Albania = 'al',\n Andorra = 'ad',\n UnitedArabEmirates = 'ae',\n Argentina = 'ar',\n Armenia = 'am',\n AntiguaAndBarbuda = 'ag',\n Australia = 'au',\n Austria = 'at',\n Azerbaijan = 'az',\n Burundi = 'bi',\n Belgium = 'be',\n Benin = 'bj',\n BurkinaFaso = 'bf',\n Bangladesh = 'bd',\n Bulgaria = 'bg',\n Bahrain = 'bh',\n Bahamas = 'bs',\n BosniaAndHerzegovina = 'ba',\n Belarus = 'by',\n Belize = 'bz',\n Bolivia = 'bo',\n Brazil = 'br',\n Barbados = 'bb',\n BruneiDarussalam = 'bn',\n Bhutan = 'bt',\n Botswana = 'bw',\n CentralAfricanRepublic = 'cf',\n Canada = 'ca',\n Switzerland = 'ch',\n Chile = 'cl',\n China = 'cn',\n CoteDIvoire = 'ci',\n Cameroon = 'cm',\n DemocraticRepublicOfTheCongo = 'cd',\n RepublicOfTheCongo = 'cg',\n Colombia = 'co',\n Comoros = 'km',\n CapeVerde = 'cv',\n CostaRica = 'cr',\n Cuba = 'cu',\n Cyprus = 'cy',\n CzechRepublic = 'cz',\n Germany = 'de',\n Djibouti = 'dj',\n Dominica = 'dm',\n Denmark = 'dk',\n DominicanRepublic = 'do',\n Algeria = 'dz',\n Ecuador = 'ec',\n Egypt = 'eg',\n Eritrea = 'er',\n Spain = 'es',\n Estonia = 'ee',\n Ethiopia = 'et',\n Finland = 'fi',\n Fiji = 'fj',\n France = 'fr',\n MicronesiaFederatedStatesOf = 'fm',\n Gabon = 'ga',\n UnitedKingdom = 'gb',\n Georgia = 'ge',\n Ghana = 'gh',\n Guinea = 'gn',\n Gambia = 'gm',\n GuineaBissau = 'gw',\n EquatorialGuinea = 'gq',\n Greece = 'gr',\n Grenada = 'gd',\n Guatemala = 'gt',\n Guyana = 'gy',\n Honduras = 'hn',\n Croatia = 'hr',\n Haiti = 'ht',\n Hungary = 'hu',\n Indonesia = 'id',\n India = 'in',\n Ireland = 'ie',\n IranIslamicRepublicOf = 'ir',\n Iraq = 'iq',\n Iceland = 'is',\n Israel = 'il',\n Italy = 'it',\n Jamaica = 'jm',\n Jordan = 'jo',\n Japan = 'jp',\n Kazakhstan = 'kz',\n Kenya = 'ke',\n Kyrgyzstan = 'kg',\n Cambodia = 'kh',\n Kiribati = 'ki',\n SaintKittsAndNevis = 'kn',\n SouthKorea = 'kr',\n Kuwait = 'kw',\n LaoPeopleSDemocraticRepublic = 'la',\n Lebanon = 'lb',\n Liberia = 'lr',\n Libya = 'ly',\n SaintLucia = 'lc',\n Liechtenstein = 'li',\n SriLanka = 'lk',\n Lesotho = 'ls',\n Lithuania = 'lt',\n Luxembourg = 'lu',\n Latvia = 'lv',\n Morocco = 'ma',\n Monaco = 'mc',\n Moldova = 'md',\n Madagascar = 'mg',\n Maldives = 'mv',\n Mexico = 'mx',\n MarshallIslands = 'mh',\n NorthMacedonia = 'mk',\n Mali = 'ml',\n Malta = 'mt',\n Myanmar = 'mm',\n Montenegro = 'me',\n Mongolia = 'mn',\n Mozambique = 'mz',\n Mauritania = 'mr',\n Mauritius = 'mu',\n Malawi = 'mw',\n Malaysia = 'my',\n Namibia = 'na',\n Niger = 'ne',\n Nigeria = 'ng',\n Nicaragua = 'ni',\n Netherlands = 'nl',\n Norway = 'no',\n Nepal = 'np',\n Nauru = 'nr',\n NewZealand = 'nz',\n Oman = 'om',\n Pakistan = 'pk',\n Panama = 'pa',\n Peru = 'pe',\n Philippines = 'ph',\n Palau = 'pw',\n PapuaNewGuinea = 'pg',\n Poland = 'pl',\n FrenchPolynesia = 'pf',\n NorthKorea = 'kp',\n Portugal = 'pt',\n Paraguay = 'py',\n Qatar = 'qa',\n Romania = 'ro',\n Russia = 'ru',\n Rwanda = 'rw',\n SaudiArabia = 'sa',\n Sudan = 'sd',\n Senegal = 'sn',\n Singapore = 'sg',\n SolomonIslands = 'sb',\n SierraLeone = 'sl',\n ElSalvador = 'sv',\n SanMarino = 'sm',\n Somalia = 'so',\n Serbia = 'rs',\n SouthSudan = 'ss',\n SaoTomeAndPrincipe = 'st',\n Suriname = 'sr',\n Slovakia = 'sk',\n Slovenia = 'si',\n Sweden = 'se',\n Eswatini = 'sz',\n Seychelles = 'sc',\n Syria = 'sy',\n Chad = 'td',\n Togo = 'tg',\n Thailand = 'th',\n Tajikistan = 'tj',\n Turkmenistan = 'tm',\n TimorLeste = 'tl',\n Tonga = 'to',\n TrinidadAndTobago = 'tt',\n Tunisia = 'tn',\n Turkey = 'tr',\n Tuvalu = 'tv',\n Tanzania = 'tz',\n Uganda = 'ug',\n Ukraine = 'ua',\n Uruguay = 'uy',\n UnitedStates = 'us',\n Uzbekistan = 'uz',\n VaticanCity = 'va',\n SaintVincentAndTheGrenadines = 'vc',\n Venezuela = 've',\n Vietnam = 'vn',\n Vanuatu = 'vu',\n Samoa = 'ws',\n Yemen = 'ye',\n SouthAfrica = 'za',\n Zambia = 'zm',\n Zimbabwe = 'zw',\n}","export enum ExecutionMethod {\n GET = 'GET',\n POST = 'POST',\n PUT = 'PUT',\n PATCH = 'PATCH',\n DELETE = 'DELETE',\n OPTIONS = 'OPTIONS',\n HEAD = 'HEAD',\n}","export enum ImageGravity {\n Center = 'center',\n TopLeft = 'top-left',\n Top = 'top',\n TopRight = 'top-right',\n Left = 'left',\n Right = 'right',\n BottomLeft = 'bottom-left',\n Bottom = 'bottom',\n BottomRight = 'bottom-right',\n}","export enum ImageFormat {\n Jpg = 'jpg',\n Jpeg = 'jpeg',\n Png = 'png',\n Webp = 'webp',\n Heic = 'heic',\n Avif = 'avif',\n Gif = 'gif',\n}"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"sdk.js","sources":["../../node_modules/tslib/tslib.es6.js","../../src/service.ts","../../src/client.ts","../../src/services/account.ts","../../src/services/avatars.ts","../../src/services/databases.ts","../../src/services/functions.ts","../../src/services/graphql.ts","../../src/services/locale.ts","../../src/services/messaging.ts","../../src/services/storage.ts","../../src/services/tables-db.ts","../../src/services/teams.ts","../../src/query.ts","../../src/permission.ts","../../src/role.ts","../../src/id.ts","../../src/enums/authenticator-type.ts","../../src/enums/authentication-factor.ts","../../src/enums/o-auth-provider.ts","../../src/enums/browser.ts","../../src/enums/credit-card.ts","../../src/enums/flag.ts","../../src/enums/execution-method.ts","../../src/enums/image-gravity.ts","../../src/enums/image-format.ts"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","import { Client } from './client';\nimport type { Payload } from './client';\n\nexport class Service {\n static CHUNK_SIZE = 5*1024*1024; // 5MB\n\n client: Client;\n\n constructor(client: Client) {\n this.client = client;\n }\n\n static flatten(data: Payload, prefix = ''): Payload {\n let output: Payload = {};\n\n for (const [key, value] of Object.entries(data)) {\n let finalKey = prefix ? prefix + '[' + key +']' : key;\n if (Array.isArray(value)) {\n output = { ...output, ...Service.flatten(value, finalKey) };\n } else {\n output[finalKey] = value;\n }\n }\n\n return output;\n }\n}","import { Models } from './models';\nimport { Service } from './service';\nimport { Platform } from 'react-native';\n\ntype Payload = {\n [key: string]: any;\n}\n\ntype Headers = {\n [key: string]: string;\n}\n\ntype RealtimeResponse = {\n type: 'error' | 'event' | 'connected' | 'response' | 'pong';\n data: RealtimeResponseAuthenticated | RealtimeResponseConnected | RealtimeResponseError | RealtimeResponseEvent<unknown> | undefined;\n}\n\ntype RealtimeRequest = {\n type: 'authentication';\n data: RealtimeRequestAuthenticate;\n}\n\nexport type RealtimeResponseEvent<T extends unknown> = {\n events: string[];\n channels: string[];\n timestamp: number;\n payload: T;\n}\n\ntype RealtimeResponseError = {\n code: number;\n message: string;\n}\n\ntype RealtimeResponseConnected = {\n channels: string[];\n user?: object;\n}\n\ntype RealtimeResponseAuthenticated = {\n to: string;\n success: boolean;\n user: object;\n}\n\ntype RealtimeRequestAuthenticate = {\n session: string;\n}\n\ntype Realtime = {\n socket?: WebSocket;\n\n /**\n * Timeout for reconnect operations.\n */\n timeout?: number;\n\n /**\n * Heartbeat interval for the realtime connection.\n */\n heartbeat?: number;\n\n url?: string;\n lastMessage?: RealtimeResponse;\n channels: Set<string>;\n subscriptions: Map<number, {\n channels: string[];\n callback: (payload: RealtimeResponseEvent<any>) => void\n }>;\n subscriptionsCounter: number;\n reconnect: boolean;\n reconnectAttempts: number;\n getTimeout: () => number;\n connect: () => void;\n createSocket: () => void;\n createHeartbeat: () => void;\n cleanUp: (channels: string[]) => void;\n onMessage: (event: MessageEvent) => void;\n}\n\nexport type UploadProgress = {\n $id: string;\n progress: number;\n sizeUploaded: number;\n chunksTotal: number;\n chunksUploaded: number;\n}\n\nclass AppwriteException extends Error {\n code: number;\n response: string;\n type: string;\n constructor(message: string, code: number = 0, type: string = '', response: string = '') {\n super(message);\n this.name = 'AppwriteException';\n this.message = message;\n this.code = code;\n this.type = type;\n this.response = response;\n }\n}\n\nclass Client {\n config = {\n endpoint: 'https://cloud.appwrite.io/v1',\n endpointRealtime: '',\n project: '',\n jwt: '',\n locale: '',\n session: '',\n devkey: '',\n platform: '',\n };\n headers: Headers = {\n 'x-sdk-name': 'React Native',\n 'x-sdk-platform': 'client',\n 'x-sdk-language': 'reactnative',\n 'x-sdk-version': '0.15.0',\n 'X-Appwrite-Response-Format': '1.8.0',\n };\n\n /**\n * Set Endpoint\n *\n * Your project endpoint\n *\n * @param {string} endpoint\n *\n * @returns {this}\n */\n setEndpoint(endpoint: string): this {\n if (!endpoint.startsWith('http://') && !endpoint.startsWith('https://')) {\n throw new AppwriteException('Invalid endpoint URL: ' + endpoint);\n }\n\n this.config.endpoint = endpoint;\n this.config.endpointRealtime = endpoint.replace('https://', 'wss://').replace('http://', 'ws://');\n\n return this;\n }\n\n /**\n * Set Realtime Endpoint\n *\n * @param {string} endpointRealtime\n *\n * @returns {this}\n */\n setEndpointRealtime(endpointRealtime: string): this {\n if (!endpointRealtime.startsWith('ws://') && !endpointRealtime.startsWith('wss://')) {\n throw new AppwriteException('Invalid realtime endpoint URL: ' + endpointRealtime);\n }\n\n this.config.endpointRealtime = endpointRealtime;\n return this;\n }\n\n /**\n * Set platform\n * \n * Set platform. Will be used as origin for all requests.\n * \n * @param {string} platform\n * @returns {this}\n */\n setPlatform(platform: string): this {\n this.config.platform = platform;\n\n return this;\n }\n\n /**\n * Set Project\n *\n * Your project ID\n *\n * @param value string\n *\n * @return {this}\n */\n setProject(value: string): this {\n this.headers['X-Appwrite-Project'] = value;\n this.config.project = value;\n return this;\n }\n\n /**\n * Set JWT\n *\n * Your secret JSON Web Token\n *\n * @param value string\n *\n * @return {this}\n */\n setJWT(value: string): this {\n this.headers['X-Appwrite-JWT'] = value;\n this.config.jwt = value;\n return this;\n }\n\n /**\n * Set Locale\n *\n * @param value string\n *\n * @return {this}\n */\n setLocale(value: string): this {\n this.headers['X-Appwrite-Locale'] = value;\n this.config.locale = value;\n return this;\n }\n\n /**\n * Set Session\n *\n * The user session to authenticate with\n *\n * @param value string\n *\n * @return {this}\n */\n setSession(value: string): this {\n this.headers['X-Appwrite-Session'] = value;\n this.config.session = value;\n return this;\n }\n\n /**\n * Set DevKey\n *\n * Your secret dev API key\n *\n * @param value string\n *\n * @return {this}\n */\n setDevKey(value: string): this {\n this.headers['X-Appwrite-Dev-Key'] = value;\n this.config.devkey = value;\n return this;\n }\n\n\n private realtime: Realtime = {\n socket: undefined,\n timeout: undefined,\n heartbeat: undefined,\n url: '',\n channels: new Set(),\n subscriptions: new Map(),\n subscriptionsCounter: 0,\n reconnect: true,\n reconnectAttempts: 0,\n lastMessage: undefined,\n connect: () => {\n clearTimeout(this.realtime.timeout);\n this.realtime.timeout = window?.setTimeout(() => {\n this.realtime.createSocket();\n }, 50);\n },\n getTimeout: () => {\n switch (true) {\n case this.realtime.reconnectAttempts < 5:\n return 1000;\n case this.realtime.reconnectAttempts < 15:\n return 5000;\n case this.realtime.reconnectAttempts < 100:\n return 10_000;\n default:\n return 60_000;\n }\n },\n createHeartbeat: () => {\n if (this.realtime.heartbeat) {\n clearTimeout(this.realtime.heartbeat);\n }\n\n this.realtime.heartbeat = window?.setInterval(() => {\n this.realtime.socket?.send(JSON.stringify({\n type: 'ping'\n }));\n }, 20_000);\n },\n createSocket: () => {\n if (this.realtime.channels.size < 1) {\n this.realtime.reconnect = false;\n this.realtime.socket?.close();\n return;\n }\n\n const channels = new URLSearchParams();\n channels.set('project', this.config.project);\n this.realtime.channels.forEach(channel => {\n channels.append('channels[]', channel);\n });\n\n const url = this.config.endpointRealtime + '/realtime?' + channels.toString();\n\n if (\n url !== this.realtime.url || // Check if URL is present\n !this.realtime.socket || // Check if WebSocket has not been created\n this.realtime.socket?.readyState > WebSocket.OPEN // Check if WebSocket is CLOSING (3) or CLOSED (4)\n ) {\n if (\n this.realtime.socket &&\n this.realtime.socket?.readyState < WebSocket.CLOSING // Close WebSocket if it is CONNECTING (0) or OPEN (1)\n ) {\n this.realtime.reconnect = false;\n this.realtime.socket.close();\n }\n\n this.realtime.url = url;\n // @ts-ignore\n this.realtime.socket = new WebSocket(url, undefined, {\n headers: {\n Origin: `appwrite-${Platform.OS}://${this.config.platform}`\n }\n });\n this.realtime.socket.addEventListener('message', this.realtime.onMessage);\n this.realtime.socket.addEventListener('open', _event => {\n this.realtime.reconnectAttempts = 0;\n this.realtime.createHeartbeat();\n });\n this.realtime.socket.addEventListener('close', event => {\n if (\n !this.realtime.reconnect ||\n (\n this.realtime?.lastMessage?.type === 'error' && // Check if last message was of type error\n (<RealtimeResponseError>this.realtime?.lastMessage.data).code === 1008 // Check for policy violation 1008\n )\n ) {\n this.realtime.reconnect = true;\n return;\n }\n\n const timeout = this.realtime.getTimeout();\n console.error(`Realtime got disconnected. Reconnect will be attempted in ${timeout / 1000} seconds.`, event.reason);\n\n setTimeout(() => {\n this.realtime.reconnectAttempts++;\n this.realtime.createSocket();\n }, timeout);\n })\n }\n },\n onMessage: (event) => {\n try {\n const message: RealtimeResponse = JSON.parse(event.data);\n this.realtime.lastMessage = message;\n switch (message.type) {\n case 'event':\n let data = <RealtimeResponseEvent<unknown>>message.data;\n if (data?.channels) {\n const isSubscribed = data.channels.some(channel => this.realtime.channels.has(channel));\n if (!isSubscribed) return;\n this.realtime.subscriptions.forEach(subscription => {\n if (data.channels.some(channel => subscription.channels.includes(channel))) {\n setTimeout(() => subscription.callback(data));\n }\n })\n }\n break;\n case 'pong':\n break; // Handle pong response if needed\n case 'error':\n throw message.data;\n default:\n break;\n }\n } catch (e) {\n console.error(e);\n }\n },\n cleanUp: channels => {\n this.realtime.channels.forEach(channel => {\n if (channels.includes(channel)) {\n let found = Array.from(this.realtime.subscriptions).some(([_key, subscription] )=> {\n return subscription.channels.includes(channel);\n })\n\n if (!found) {\n this.realtime.channels.delete(channel);\n }\n }\n })\n }\n }\n\n /**\n * Subscribes to Appwrite events and passes you the payload in realtime.\n * \n * @param {string|string[]} channels \n * Channel to subscribe - pass a single channel as a string or multiple with an array of strings.\n * \n * Possible channels are:\n * - account\n * - collections\n * - collections.[ID]\n * - collections.[ID].documents\n * - documents\n * - documents.[ID]\n * - files\n * - files.[ID]\n * - executions\n * - executions.[ID]\n * - functions.[ID]\n * - teams\n * - teams.[ID]\n * - memberships\n * - memberships.[ID]\n * @param {(payload: RealtimeMessage) => void} callback Is called on every realtime update.\n * @returns {() => void} Unsubscribes from events.\n */\n subscribe<T extends unknown>(channels: string | string[], callback: (payload: RealtimeResponseEvent<T>) => void): () => void {\n let channelArray = typeof channels === 'string' ? [channels] : channels;\n channelArray.forEach(channel => this.realtime.channels.add(channel));\n\n const counter = this.realtime.subscriptionsCounter++;\n this.realtime.subscriptions.set(counter, {\n channels: channelArray,\n callback\n });\n\n this.realtime.connect();\n\n return () => {\n this.realtime.subscriptions.delete(counter);\n this.realtime.cleanUp(channelArray);\n this.realtime.connect();\n }\n }\n\n async call(method: string, url: URL, headers: Headers = {}, params: Payload = {}, responseType = 'json'): Promise<any> {\n method = method.toUpperCase();\n\n headers = Object.assign({}, this.headers, headers);\n headers.Origin = `appwrite-${Platform.OS}://${this.config.platform}`\n\n let options: RequestInit = {\n method,\n headers,\n };\n\n if (headers['X-Appwrite-Dev-Key'] === undefined) {\n options.credentials = 'include';\n }\n\n if (method === 'GET') {\n for (const [key, value] of Object.entries(Service.flatten(params))) {\n url.searchParams.append(key, value);\n }\n } else {\n switch (headers['content-type']) {\n case 'application/json':\n options.body = JSON.stringify(params);\n break;\n\n case 'multipart/form-data':\n let formData = new FormData();\n\n for (const key in params) {\n if (Array.isArray(params[key])) {\n params[key].forEach((value: any) => {\n formData.append(key + '[]', value);\n })\n } else {\n formData.append(key, params[key]);\n }\n }\n\n options.body = formData;\n delete headers['content-type'];\n break;\n }\n }\n\n try {\n let data = null;\n\n const response = await fetch(url.toString(), options);\n\n const warnings = response.headers.get('x-appwrite-warning');\n if (warnings) {\n warnings.split(';').forEach((warning: string) => console.warn('Warning: ' + warning));\n }\n\n if (response.headers.get('content-type')?.includes('application/json')) {\n data = await response.json();\n } else if (responseType === 'arrayBuffer') {\n data = await response.arrayBuffer();\n } else {\n data = {\n message: await response.text()\n };\n }\n\n if (400 <= response.status) {\n let responseText = '';\n if (response.headers.get('content-type')?.includes('application/json')) {\n responseText = JSON.stringify(data);\n } else {\n responseText = data?.message;\n }\n throw new AppwriteException(data?.message, response.status, data?.type, responseText);\n }\n\n const cookieFallback = response.headers.get('X-Fallback-Cookies');\n\n if (typeof window !== 'undefined' && window.localStorage && cookieFallback) {\n window.console.warn('Appwrite is using localStorage for session management. Increase your security by adding a custom domain as your API endpoint.');\n window.localStorage.setItem('cookieFallback', cookieFallback);\n }\n\n return data;\n } catch (e) {\n if (e instanceof AppwriteException) {\n throw e;\n }\n throw new AppwriteException((<Error>e).message);\n }\n }\n}\n\nexport { Client, AppwriteException };\nexport type { Models, Payload };\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\nimport { AuthenticatorType } from '../enums/authenticator-type';\nimport { AuthenticationFactor } from '../enums/authentication-factor';\nimport { OAuthProvider } from '../enums/o-auth-provider';\n\nexport class Account extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Get the currently logged in user.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n get<Preferences extends Models.Preferences = Models.DefaultPreferences>(): Promise<Models.User<Preferences>> {\n const apiPath = '/account';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Use this endpoint to allow a new user to register a new account in your project. After the user registration completes successfully, you can use the [/account/verfication](https://appwrite.io/docs/references/cloud/client-web/account#createVerification) route to start verifying the user email address. To allow the new user to login to their new account, you need to create a new [account session](https://appwrite.io/docs/references/cloud/client-web/account#createEmailSession).\n *\n * @param {string} params.userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} params.email - User email.\n * @param {string} params.password - New user password. Must be between 8 and 256 chars.\n * @param {string} params.name - User name. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n create<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { userId: string, email: string, password: string, name?: string }): Promise<Models.User<Preferences>>;\n /**\n * Use this endpoint to allow a new user to register a new account in your project. After the user registration completes successfully, you can use the [/account/verfication](https://appwrite.io/docs/references/cloud/client-web/account#createVerification) route to start verifying the user email address. To allow the new user to login to their new account, you need to create a new [account session](https://appwrite.io/docs/references/cloud/client-web/account#createEmailSession).\n *\n * @param {string} userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} email - User email.\n * @param {string} password - New user password. Must be between 8 and 256 chars.\n * @param {string} name - User name. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n create<Preferences extends Models.Preferences = Models.DefaultPreferences>(userId: string, email: string, password: string, name?: string): Promise<Models.User<Preferences>>;\n create<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { userId: string, email: string, password: string, name?: string } | string,\n ...rest: [(string)?, (string)?, (string)?] \n ): Promise<Models.User<Preferences>> {\n let params: { userId: string, email: string, password: string, name?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, email: string, password: string, name?: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n email: rest[0] as string,\n password: rest[1] as string,\n name: rest[2] as string \n };\n }\n\n const userId = params.userId;\n const email = params.email;\n const password = params.password;\n const name = params.name;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof email === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"email\"');\n }\n\n if (typeof password === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"password\"');\n }\n\n const apiPath = '/account';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof email !== 'undefined') {\n payload['email'] = email;\n }\n\n if (typeof password !== 'undefined') {\n payload['password'] = password;\n }\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Update currently logged in user account email address. After changing user address, the user confirmation status will get reset. A new confirmation email is not sent automatically however you can use the send confirmation email endpoint again to send the confirmation email. For security measures, user password is required to complete this request.\n * This endpoint can also be used to convert an anonymous account to a normal one, by passing an email address and a new password.\n * \n *\n * @param {string} params.email - User email.\n * @param {string} params.password - User password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateEmail<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { email: string, password: string }): Promise<Models.User<Preferences>>;\n /**\n * Update currently logged in user account email address. After changing user address, the user confirmation status will get reset. A new confirmation email is not sent automatically however you can use the send confirmation email endpoint again to send the confirmation email. For security measures, user password is required to complete this request.\n * This endpoint can also be used to convert an anonymous account to a normal one, by passing an email address and a new password.\n * \n *\n * @param {string} email - User email.\n * @param {string} password - User password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateEmail<Preferences extends Models.Preferences = Models.DefaultPreferences>(email: string, password: string): Promise<Models.User<Preferences>>;\n updateEmail<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { email: string, password: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.User<Preferences>> {\n let params: { email: string, password: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { email: string, password: string };\n } else {\n params = {\n email: paramsOrFirst as string,\n password: rest[0] as string \n };\n }\n\n const email = params.email;\n const password = params.password;\n\n if (typeof email === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"email\"');\n }\n\n if (typeof password === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"password\"');\n }\n\n const apiPath = '/account/email';\n const payload: Payload = {};\n\n if (typeof email !== 'undefined') {\n payload['email'] = email;\n }\n\n if (typeof password !== 'undefined') {\n payload['password'] = password;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get the list of identities for the currently logged in user.\n *\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: userId, provider, providerUid, providerEmail, providerAccessTokenExpiry\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listIdentities(params?: { queries?: string[] }): Promise<Models.IdentityList>;\n /**\n * Get the list of identities for the currently logged in user.\n *\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: userId, provider, providerUid, providerEmail, providerAccessTokenExpiry\n * @throws {AppwriteException}\n * @returns {Promise<Models.IdentityList>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n listIdentities(queries?: string[]): Promise<Models.IdentityList>;\n listIdentities(\n paramsOrFirst?: { queries?: string[] } | string[] \n ): Promise<Models.IdentityList> {\n let params: { queries?: string[] };\n\n if (!paramsOrFirst || (paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { queries?: string[] };\n } else {\n params = {\n queries: paramsOrFirst as string[] \n };\n }\n\n const queries = params.queries;\n\n const apiPath = '/account/identities';\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Delete an identity by its unique ID.\n *\n * @param {string} params.identityId - Identity ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteIdentity(params: { identityId: string }): Promise<{}>;\n /**\n * Delete an identity by its unique ID.\n *\n * @param {string} identityId - Identity ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteIdentity(identityId: string): Promise<{}>;\n deleteIdentity(\n paramsOrFirst: { identityId: string } | string \n ): Promise<{}> {\n let params: { identityId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { identityId: string };\n } else {\n params = {\n identityId: paramsOrFirst as string \n };\n }\n\n const identityId = params.identityId;\n\n if (typeof identityId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"identityId\"');\n }\n\n const apiPath = '/account/identities/{identityId}'.replace('{identityId}', identityId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to create a JSON Web Token. You can use the resulting JWT to authenticate on behalf of the current user when working with the Appwrite server-side API and SDKs. The JWT secret is valid for 15 minutes from its creation and will be invalid if the user will logout in that time frame.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createJWT(): Promise<Models.Jwt> {\n const apiPath = '/account/jwts';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get the list of latest security activity logs for the currently logged in user. Each log returns user IP address, location and date and time of log.\n *\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Only supported methods are limit and offset\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listLogs(params?: { queries?: string[] }): Promise<Models.LogList>;\n /**\n * Get the list of latest security activity logs for the currently logged in user. Each log returns user IP address, location and date and time of log.\n *\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Only supported methods are limit and offset\n * @throws {AppwriteException}\n * @returns {Promise<Models.LogList>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n listLogs(queries?: string[]): Promise<Models.LogList>;\n listLogs(\n paramsOrFirst?: { queries?: string[] } | string[] \n ): Promise<Models.LogList> {\n let params: { queries?: string[] };\n\n if (!paramsOrFirst || (paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { queries?: string[] };\n } else {\n params = {\n queries: paramsOrFirst as string[] \n };\n }\n\n const queries = params.queries;\n\n const apiPath = '/account/logs';\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Enable or disable MFA on an account.\n *\n * @param {boolean} params.mfa - Enable or disable MFA.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateMFA<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { mfa: boolean }): Promise<Models.User<Preferences>>;\n /**\n * Enable or disable MFA on an account.\n *\n * @param {boolean} mfa - Enable or disable MFA.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMFA<Preferences extends Models.Preferences = Models.DefaultPreferences>(mfa: boolean): Promise<Models.User<Preferences>>;\n updateMFA<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { mfa: boolean } | boolean \n ): Promise<Models.User<Preferences>> {\n let params: { mfa: boolean };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { mfa: boolean };\n } else {\n params = {\n mfa: paramsOrFirst as boolean \n };\n }\n\n const mfa = params.mfa;\n\n if (typeof mfa === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"mfa\"');\n }\n\n const apiPath = '/account/mfa';\n const payload: Payload = {};\n\n if (typeof mfa !== 'undefined') {\n payload['mfa'] = mfa;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Add an authenticator app to be used as an MFA factor. Verify the authenticator using the [verify authenticator](/docs/references/cloud/client-web/account#updateMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} params.type - Type of authenticator. Must be `totp`\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.createMFAAuthenticator` instead.\n */\n createMfaAuthenticator(params: { type: AuthenticatorType }): Promise<Models.MfaType>;\n /**\n * Add an authenticator app to be used as an MFA factor. Verify the authenticator using the [verify authenticator](/docs/references/cloud/client-web/account#updateMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} type - Type of authenticator. Must be `totp`\n * @throws {AppwriteException}\n * @returns {Promise<Models.MfaType>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createMfaAuthenticator(type: AuthenticatorType): Promise<Models.MfaType>;\n createMfaAuthenticator(\n paramsOrFirst: { type: AuthenticatorType } | AuthenticatorType \n ): Promise<Models.MfaType> {\n let params: { type: AuthenticatorType };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'type' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { type: AuthenticatorType };\n } else {\n params = {\n type: paramsOrFirst as AuthenticatorType \n };\n }\n\n const type = params.type;\n\n if (typeof type === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"type\"');\n }\n\n const apiPath = '/account/mfa/authenticators/{type}'.replace('{type}', type);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Add an authenticator app to be used as an MFA factor. Verify the authenticator using the [verify authenticator](/docs/references/cloud/client-web/account#updateMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} params.type - Type of authenticator. Must be `totp`\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createMFAAuthenticator(params: { type: AuthenticatorType }): Promise<Models.MfaType>;\n /**\n * Add an authenticator app to be used as an MFA factor. Verify the authenticator using the [verify authenticator](/docs/references/cloud/client-web/account#updateMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} type - Type of authenticator. Must be `totp`\n * @throws {AppwriteException}\n * @returns {Promise<Models.MfaType>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createMFAAuthenticator(type: AuthenticatorType): Promise<Models.MfaType>;\n createMFAAuthenticator(\n paramsOrFirst: { type: AuthenticatorType } | AuthenticatorType \n ): Promise<Models.MfaType> {\n let params: { type: AuthenticatorType };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'type' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { type: AuthenticatorType };\n } else {\n params = {\n type: paramsOrFirst as AuthenticatorType \n };\n }\n\n const type = params.type;\n\n if (typeof type === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"type\"');\n }\n\n const apiPath = '/account/mfa/authenticators/{type}'.replace('{type}', type);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Verify an authenticator app after adding it using the [add authenticator](/docs/references/cloud/client-web/account#createMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} params.type - Type of authenticator.\n * @param {string} params.otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.updateMFAAuthenticator` instead.\n */\n updateMfaAuthenticator<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { type: AuthenticatorType, otp: string }): Promise<Models.User<Preferences>>;\n /**\n * Verify an authenticator app after adding it using the [add authenticator](/docs/references/cloud/client-web/account#createMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} type - Type of authenticator.\n * @param {string} otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMfaAuthenticator<Preferences extends Models.Preferences = Models.DefaultPreferences>(type: AuthenticatorType, otp: string): Promise<Models.User<Preferences>>;\n updateMfaAuthenticator<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { type: AuthenticatorType, otp: string } | AuthenticatorType,\n ...rest: [(string)?] \n ): Promise<Models.User<Preferences>> {\n let params: { type: AuthenticatorType, otp: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'type' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { type: AuthenticatorType, otp: string };\n } else {\n params = {\n type: paramsOrFirst as AuthenticatorType,\n otp: rest[0] as string \n };\n }\n\n const type = params.type;\n const otp = params.otp;\n\n if (typeof type === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"type\"');\n }\n\n if (typeof otp === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"otp\"');\n }\n\n const apiPath = '/account/mfa/authenticators/{type}'.replace('{type}', type);\n const payload: Payload = {};\n\n if (typeof otp !== 'undefined') {\n payload['otp'] = otp;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Verify an authenticator app after adding it using the [add authenticator](/docs/references/cloud/client-web/account#createMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} params.type - Type of authenticator.\n * @param {string} params.otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateMFAAuthenticator<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { type: AuthenticatorType, otp: string }): Promise<Models.User<Preferences>>;\n /**\n * Verify an authenticator app after adding it using the [add authenticator](/docs/references/cloud/client-web/account#createMfaAuthenticator) method.\n *\n * @param {AuthenticatorType} type - Type of authenticator.\n * @param {string} otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMFAAuthenticator<Preferences extends Models.Preferences = Models.DefaultPreferences>(type: AuthenticatorType, otp: string): Promise<Models.User<Preferences>>;\n updateMFAAuthenticator<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { type: AuthenticatorType, otp: string } | AuthenticatorType,\n ...rest: [(string)?] \n ): Promise<Models.User<Preferences>> {\n let params: { type: AuthenticatorType, otp: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'type' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { type: AuthenticatorType, otp: string };\n } else {\n params = {\n type: paramsOrFirst as AuthenticatorType,\n otp: rest[0] as string \n };\n }\n\n const type = params.type;\n const otp = params.otp;\n\n if (typeof type === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"type\"');\n }\n\n if (typeof otp === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"otp\"');\n }\n\n const apiPath = '/account/mfa/authenticators/{type}'.replace('{type}', type);\n const payload: Payload = {};\n\n if (typeof otp !== 'undefined') {\n payload['otp'] = otp;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete an authenticator for a user by ID.\n *\n * @param {AuthenticatorType} params.type - Type of authenticator.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.deleteMFAAuthenticator` instead.\n */\n deleteMfaAuthenticator(params: { type: AuthenticatorType }): Promise<{}>;\n /**\n * Delete an authenticator for a user by ID.\n *\n * @param {AuthenticatorType} type - Type of authenticator.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteMfaAuthenticator(type: AuthenticatorType): Promise<{}>;\n deleteMfaAuthenticator(\n paramsOrFirst: { type: AuthenticatorType } | AuthenticatorType \n ): Promise<{}> {\n let params: { type: AuthenticatorType };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'type' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { type: AuthenticatorType };\n } else {\n params = {\n type: paramsOrFirst as AuthenticatorType \n };\n }\n\n const type = params.type;\n\n if (typeof type === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"type\"');\n }\n\n const apiPath = '/account/mfa/authenticators/{type}'.replace('{type}', type);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete an authenticator for a user by ID.\n *\n * @param {AuthenticatorType} params.type - Type of authenticator.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteMFAAuthenticator(params: { type: AuthenticatorType }): Promise<{}>;\n /**\n * Delete an authenticator for a user by ID.\n *\n * @param {AuthenticatorType} type - Type of authenticator.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteMFAAuthenticator(type: AuthenticatorType): Promise<{}>;\n deleteMFAAuthenticator(\n paramsOrFirst: { type: AuthenticatorType } | AuthenticatorType \n ): Promise<{}> {\n let params: { type: AuthenticatorType };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'type' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { type: AuthenticatorType };\n } else {\n params = {\n type: paramsOrFirst as AuthenticatorType \n };\n }\n\n const type = params.type;\n\n if (typeof type === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"type\"');\n }\n\n const apiPath = '/account/mfa/authenticators/{type}'.replace('{type}', type);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Begin the process of MFA verification after sign-in. Finish the flow with [updateMfaChallenge](/docs/references/cloud/client-web/account#updateMfaChallenge) method.\n *\n * @param {AuthenticationFactor} params.factor - Factor used for verification. Must be one of following: `email`, `phone`, `totp`, `recoveryCode`.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.createMFAChallenge` instead.\n */\n createMfaChallenge(params: { factor: AuthenticationFactor }): Promise<Models.MfaChallenge>;\n /**\n * Begin the process of MFA verification after sign-in. Finish the flow with [updateMfaChallenge](/docs/references/cloud/client-web/account#updateMfaChallenge) method.\n *\n * @param {AuthenticationFactor} factor - Factor used for verification. Must be one of following: `email`, `phone`, `totp`, `recoveryCode`.\n * @throws {AppwriteException}\n * @returns {Promise<Models.MfaChallenge>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createMfaChallenge(factor: AuthenticationFactor): Promise<Models.MfaChallenge>;\n createMfaChallenge(\n paramsOrFirst: { factor: AuthenticationFactor } | AuthenticationFactor \n ): Promise<Models.MfaChallenge> {\n let params: { factor: AuthenticationFactor };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'factor' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { factor: AuthenticationFactor };\n } else {\n params = {\n factor: paramsOrFirst as AuthenticationFactor \n };\n }\n\n const factor = params.factor;\n\n if (typeof factor === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"factor\"');\n }\n\n const apiPath = '/account/mfa/challenge';\n const payload: Payload = {};\n\n if (typeof factor !== 'undefined') {\n payload['factor'] = factor;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Begin the process of MFA verification after sign-in. Finish the flow with [updateMfaChallenge](/docs/references/cloud/client-web/account#updateMfaChallenge) method.\n *\n * @param {AuthenticationFactor} params.factor - Factor used for verification. Must be one of following: `email`, `phone`, `totp`, `recoveryCode`.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createMFAChallenge(params: { factor: AuthenticationFactor }): Promise<Models.MfaChallenge>;\n /**\n * Begin the process of MFA verification after sign-in. Finish the flow with [updateMfaChallenge](/docs/references/cloud/client-web/account#updateMfaChallenge) method.\n *\n * @param {AuthenticationFactor} factor - Factor used for verification. Must be one of following: `email`, `phone`, `totp`, `recoveryCode`.\n * @throws {AppwriteException}\n * @returns {Promise<Models.MfaChallenge>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createMFAChallenge(factor: AuthenticationFactor): Promise<Models.MfaChallenge>;\n createMFAChallenge(\n paramsOrFirst: { factor: AuthenticationFactor } | AuthenticationFactor \n ): Promise<Models.MfaChallenge> {\n let params: { factor: AuthenticationFactor };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'factor' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { factor: AuthenticationFactor };\n } else {\n params = {\n factor: paramsOrFirst as AuthenticationFactor \n };\n }\n\n const factor = params.factor;\n\n if (typeof factor === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"factor\"');\n }\n\n const apiPath = '/account/mfa/challenge';\n const payload: Payload = {};\n\n if (typeof factor !== 'undefined') {\n payload['factor'] = factor;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Complete the MFA challenge by providing the one-time password. Finish the process of MFA verification by providing the one-time password. To begin the flow, use [createMfaChallenge](/docs/references/cloud/client-web/account#createMfaChallenge) method.\n *\n * @param {string} params.challengeId - ID of the challenge.\n * @param {string} params.otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.updateMFAChallenge` instead.\n */\n updateMfaChallenge(params: { challengeId: string, otp: string }): Promise<Models.Session>;\n /**\n * Complete the MFA challenge by providing the one-time password. Finish the process of MFA verification by providing the one-time password. To begin the flow, use [createMfaChallenge](/docs/references/cloud/client-web/account#createMfaChallenge) method.\n *\n * @param {string} challengeId - ID of the challenge.\n * @param {string} otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMfaChallenge(challengeId: string, otp: string): Promise<Models.Session>;\n updateMfaChallenge(\n paramsOrFirst: { challengeId: string, otp: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Session> {\n let params: { challengeId: string, otp: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { challengeId: string, otp: string };\n } else {\n params = {\n challengeId: paramsOrFirst as string,\n otp: rest[0] as string \n };\n }\n\n const challengeId = params.challengeId;\n const otp = params.otp;\n\n if (typeof challengeId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"challengeId\"');\n }\n\n if (typeof otp === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"otp\"');\n }\n\n const apiPath = '/account/mfa/challenge';\n const payload: Payload = {};\n\n if (typeof challengeId !== 'undefined') {\n payload['challengeId'] = challengeId;\n }\n\n if (typeof otp !== 'undefined') {\n payload['otp'] = otp;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Complete the MFA challenge by providing the one-time password. Finish the process of MFA verification by providing the one-time password. To begin the flow, use [createMfaChallenge](/docs/references/cloud/client-web/account#createMfaChallenge) method.\n *\n * @param {string} params.challengeId - ID of the challenge.\n * @param {string} params.otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateMFAChallenge(params: { challengeId: string, otp: string }): Promise<Models.Session>;\n /**\n * Complete the MFA challenge by providing the one-time password. Finish the process of MFA verification by providing the one-time password. To begin the flow, use [createMfaChallenge](/docs/references/cloud/client-web/account#createMfaChallenge) method.\n *\n * @param {string} challengeId - ID of the challenge.\n * @param {string} otp - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMFAChallenge(challengeId: string, otp: string): Promise<Models.Session>;\n updateMFAChallenge(\n paramsOrFirst: { challengeId: string, otp: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Session> {\n let params: { challengeId: string, otp: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { challengeId: string, otp: string };\n } else {\n params = {\n challengeId: paramsOrFirst as string,\n otp: rest[0] as string \n };\n }\n\n const challengeId = params.challengeId;\n const otp = params.otp;\n\n if (typeof challengeId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"challengeId\"');\n }\n\n if (typeof otp === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"otp\"');\n }\n\n const apiPath = '/account/mfa/challenge';\n const payload: Payload = {};\n\n if (typeof challengeId !== 'undefined') {\n payload['challengeId'] = challengeId;\n }\n\n if (typeof otp !== 'undefined') {\n payload['otp'] = otp;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * List the factors available on the account to be used as a MFA challange.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.listMFAFactors` instead.\n */\n listMfaFactors(): Promise<Models.MfaFactors> {\n const apiPath = '/account/mfa/factors';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List the factors available on the account to be used as a MFA challange.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listMFAFactors(): Promise<Models.MfaFactors> {\n const apiPath = '/account/mfa/factors';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Get recovery codes that can be used as backup for MFA flow. Before getting codes, they must be generated using [createMfaRecoveryCodes](/docs/references/cloud/client-web/account#createMfaRecoveryCodes) method. An OTP challenge is required to read recovery codes.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.getMFARecoveryCodes` instead.\n */\n getMfaRecoveryCodes(): Promise<Models.MfaRecoveryCodes> {\n const apiPath = '/account/mfa/recovery-codes';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Get recovery codes that can be used as backup for MFA flow. Before getting codes, they must be generated using [createMfaRecoveryCodes](/docs/references/cloud/client-web/account#createMfaRecoveryCodes) method. An OTP challenge is required to read recovery codes.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getMFARecoveryCodes(): Promise<Models.MfaRecoveryCodes> {\n const apiPath = '/account/mfa/recovery-codes';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Generate recovery codes as backup for MFA flow. It's recommended to generate and show then immediately after user successfully adds their authehticator. Recovery codes can be used as a MFA verification type in [createMfaChallenge](/docs/references/cloud/client-web/account#createMfaChallenge) method.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.createMFARecoveryCodes` instead.\n */\n createMfaRecoveryCodes(): Promise<Models.MfaRecoveryCodes> {\n const apiPath = '/account/mfa/recovery-codes';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Generate recovery codes as backup for MFA flow. It's recommended to generate and show then immediately after user successfully adds their authehticator. Recovery codes can be used as a MFA verification type in [createMfaChallenge](/docs/references/cloud/client-web/account#createMfaChallenge) method.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createMFARecoveryCodes(): Promise<Models.MfaRecoveryCodes> {\n const apiPath = '/account/mfa/recovery-codes';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Regenerate recovery codes that can be used as backup for MFA flow. Before regenerating codes, they must be first generated using [createMfaRecoveryCodes](/docs/references/cloud/client-web/account#createMfaRecoveryCodes) method. An OTP challenge is required to regenreate recovery codes.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `Account.updateMFARecoveryCodes` instead.\n */\n updateMfaRecoveryCodes(): Promise<Models.MfaRecoveryCodes> {\n const apiPath = '/account/mfa/recovery-codes';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Regenerate recovery codes that can be used as backup for MFA flow. Before regenerating codes, they must be first generated using [createMfaRecoveryCodes](/docs/references/cloud/client-web/account#createMfaRecoveryCodes) method. An OTP challenge is required to regenreate recovery codes.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateMFARecoveryCodes(): Promise<Models.MfaRecoveryCodes> {\n const apiPath = '/account/mfa/recovery-codes';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Update currently logged in user account name.\n *\n * @param {string} params.name - User name. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateName<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { name: string }): Promise<Models.User<Preferences>>;\n /**\n * Update currently logged in user account name.\n *\n * @param {string} name - User name. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateName<Preferences extends Models.Preferences = Models.DefaultPreferences>(name: string): Promise<Models.User<Preferences>>;\n updateName<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { name: string } | string \n ): Promise<Models.User<Preferences>> {\n let params: { name: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { name: string };\n } else {\n params = {\n name: paramsOrFirst as string \n };\n }\n\n const name = params.name;\n\n if (typeof name === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"name\"');\n }\n\n const apiPath = '/account/name';\n const payload: Payload = {};\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Update currently logged in user password. For validation, user is required to pass in the new password, and the old password. For users created with OAuth, Team Invites and Magic URL, oldPassword is optional.\n *\n * @param {string} params.password - New user password. Must be at least 8 chars.\n * @param {string} params.oldPassword - Current user password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updatePassword<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { password: string, oldPassword?: string }): Promise<Models.User<Preferences>>;\n /**\n * Update currently logged in user password. For validation, user is required to pass in the new password, and the old password. For users created with OAuth, Team Invites and Magic URL, oldPassword is optional.\n *\n * @param {string} password - New user password. Must be at least 8 chars.\n * @param {string} oldPassword - Current user password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updatePassword<Preferences extends Models.Preferences = Models.DefaultPreferences>(password: string, oldPassword?: string): Promise<Models.User<Preferences>>;\n updatePassword<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { password: string, oldPassword?: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.User<Preferences>> {\n let params: { password: string, oldPassword?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { password: string, oldPassword?: string };\n } else {\n params = {\n password: paramsOrFirst as string,\n oldPassword: rest[0] as string \n };\n }\n\n const password = params.password;\n const oldPassword = params.oldPassword;\n\n if (typeof password === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"password\"');\n }\n\n const apiPath = '/account/password';\n const payload: Payload = {};\n\n if (typeof password !== 'undefined') {\n payload['password'] = password;\n }\n\n if (typeof oldPassword !== 'undefined') {\n payload['oldPassword'] = oldPassword;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Update the currently logged in user's phone number. After updating the phone number, the phone verification status will be reset. A confirmation SMS is not sent automatically, however you can use the [POST /account/verification/phone](https://appwrite.io/docs/references/cloud/client-web/account#createPhoneVerification) endpoint to send a confirmation SMS.\n *\n * @param {string} params.phone - Phone number. Format this number with a leading '+' and a country code, e.g., +16175551212.\n * @param {string} params.password - User password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updatePhone<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { phone: string, password: string }): Promise<Models.User<Preferences>>;\n /**\n * Update the currently logged in user's phone number. After updating the phone number, the phone verification status will be reset. A confirmation SMS is not sent automatically, however you can use the [POST /account/verification/phone](https://appwrite.io/docs/references/cloud/client-web/account#createPhoneVerification) endpoint to send a confirmation SMS.\n *\n * @param {string} phone - Phone number. Format this number with a leading '+' and a country code, e.g., +16175551212.\n * @param {string} password - User password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updatePhone<Preferences extends Models.Preferences = Models.DefaultPreferences>(phone: string, password: string): Promise<Models.User<Preferences>>;\n updatePhone<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { phone: string, password: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.User<Preferences>> {\n let params: { phone: string, password: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { phone: string, password: string };\n } else {\n params = {\n phone: paramsOrFirst as string,\n password: rest[0] as string \n };\n }\n\n const phone = params.phone;\n const password = params.password;\n\n if (typeof phone === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"phone\"');\n }\n\n if (typeof password === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"password\"');\n }\n\n const apiPath = '/account/phone';\n const payload: Payload = {};\n\n if (typeof phone !== 'undefined') {\n payload['phone'] = phone;\n }\n\n if (typeof password !== 'undefined') {\n payload['password'] = password;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get the preferences as a key-value object for the currently logged in user.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getPrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(): Promise<Preferences> {\n const apiPath = '/account/prefs';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Update currently logged in user account preferences. The object you pass is stored as is, and replaces any previous value. The maximum allowed prefs size is 64kB and throws error if exceeded.\n *\n * @param {Partial<Preferences>} params.prefs - Prefs key-value JSON object.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updatePrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { prefs: Partial<Preferences> }): Promise<Models.User<Preferences>>;\n /**\n * Update currently logged in user account preferences. The object you pass is stored as is, and replaces any previous value. The maximum allowed prefs size is 64kB and throws error if exceeded.\n *\n * @param {Partial<Preferences>} prefs - Prefs key-value JSON object.\n * @throws {AppwriteException}\n * @returns {Promise<Models.User<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updatePrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(prefs: Partial<Preferences>): Promise<Models.User<Preferences>>;\n updatePrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { prefs: Partial<Preferences> } | Partial<Preferences> \n ): Promise<Models.User<Preferences>> {\n let params: { prefs: Partial<Preferences> };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'prefs' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { prefs: Partial<Preferences> };\n } else {\n params = {\n prefs: paramsOrFirst as Partial<Preferences> \n };\n }\n\n const prefs = params.prefs;\n\n if (typeof prefs === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"prefs\"');\n }\n\n const apiPath = '/account/prefs';\n const payload: Payload = {};\n\n if (typeof prefs !== 'undefined') {\n payload['prefs'] = prefs;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Sends the user an email with a temporary secret key for password reset. When the user clicks the confirmation link he is redirected back to your app password reset URL with the secret key and email address values attached to the URL query string. Use the query string params to submit a request to the [PUT /account/recovery](https://appwrite.io/docs/references/cloud/client-web/account#updateRecovery) endpoint to complete the process. The verification link sent to the user's email address is valid for 1 hour.\n *\n * @param {string} params.email - User email.\n * @param {string} params.url - URL to redirect the user back to your app from the recovery email. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createRecovery(params: { email: string, url: string }): Promise<Models.Token>;\n /**\n * Sends the user an email with a temporary secret key for password reset. When the user clicks the confirmation link he is redirected back to your app password reset URL with the secret key and email address values attached to the URL query string. Use the query string params to submit a request to the [PUT /account/recovery](https://appwrite.io/docs/references/cloud/client-web/account#updateRecovery) endpoint to complete the process. The verification link sent to the user's email address is valid for 1 hour.\n *\n * @param {string} email - User email.\n * @param {string} url - URL to redirect the user back to your app from the recovery email. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createRecovery(email: string, url: string): Promise<Models.Token>;\n createRecovery(\n paramsOrFirst: { email: string, url: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Token> {\n let params: { email: string, url: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { email: string, url: string };\n } else {\n params = {\n email: paramsOrFirst as string,\n url: rest[0] as string \n };\n }\n\n const email = params.email;\n const url = params.url;\n\n if (typeof email === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"email\"');\n }\n\n if (typeof url === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"url\"');\n }\n\n const apiPath = '/account/recovery';\n const payload: Payload = {};\n\n if (typeof email !== 'undefined') {\n payload['email'] = email;\n }\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to complete the user account password reset. Both the **userId** and **secret** arguments will be passed as query parameters to the redirect URL you have provided when sending your request to the [POST /account/recovery](https://appwrite.io/docs/references/cloud/client-web/account#createRecovery) endpoint.\n * \n * Please note that in order to avoid a [Redirect Attack](https://github.com/OWASP/CheatSheetSeries/blob/master/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.md) the only valid redirect URLs are the ones from domains you have set when adding your platforms in the console interface.\n *\n * @param {string} params.userId - User ID.\n * @param {string} params.secret - Valid reset token.\n * @param {string} params.password - New user password. Must be between 8 and 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateRecovery(params: { userId: string, secret: string, password: string }): Promise<Models.Token>;\n /**\n * Use this endpoint to complete the user account password reset. Both the **userId** and **secret** arguments will be passed as query parameters to the redirect URL you have provided when sending your request to the [POST /account/recovery](https://appwrite.io/docs/references/cloud/client-web/account#createRecovery) endpoint.\n * \n * Please note that in order to avoid a [Redirect Attack](https://github.com/OWASP/CheatSheetSeries/blob/master/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.md) the only valid redirect URLs are the ones from domains you have set when adding your platforms in the console interface.\n *\n * @param {string} userId - User ID.\n * @param {string} secret - Valid reset token.\n * @param {string} password - New user password. Must be between 8 and 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateRecovery(userId: string, secret: string, password: string): Promise<Models.Token>;\n updateRecovery(\n paramsOrFirst: { userId: string, secret: string, password: string } | string,\n ...rest: [(string)?, (string)?] \n ): Promise<Models.Token> {\n let params: { userId: string, secret: string, password: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, secret: string, password: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n secret: rest[0] as string,\n password: rest[1] as string \n };\n }\n\n const userId = params.userId;\n const secret = params.secret;\n const password = params.password;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof secret === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"secret\"');\n }\n\n if (typeof password === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"password\"');\n }\n\n const apiPath = '/account/recovery';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof secret !== 'undefined') {\n payload['secret'] = secret;\n }\n\n if (typeof password !== 'undefined') {\n payload['password'] = password;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get the list of active sessions across different devices for the currently logged in user.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listSessions(): Promise<Models.SessionList> {\n const apiPath = '/account/sessions';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Delete all sessions from the user account and remove any sessions cookies from the end client.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteSessions(): Promise<{}> {\n const apiPath = '/account/sessions';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to allow a new user to register an anonymous account in your project. This route will also create a new session for the user. To allow the new user to convert an anonymous account to a normal account, you need to update its [email and password](https://appwrite.io/docs/references/cloud/client-web/account#updateEmail) or create an [OAuth2 session](https://appwrite.io/docs/references/cloud/client-web/account#CreateOAuth2Session).\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createAnonymousSession(): Promise<Models.Session> {\n const apiPath = '/account/sessions/anonymous';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Allow the user to login into their account by providing a valid email and password combination. This route will create a new session for the user.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n *\n * @param {string} params.email - User email.\n * @param {string} params.password - User password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createEmailPasswordSession(params: { email: string, password: string }): Promise<Models.Session>;\n /**\n * Allow the user to login into their account by providing a valid email and password combination. This route will create a new session for the user.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n *\n * @param {string} email - User email.\n * @param {string} password - User password. Must be at least 8 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createEmailPasswordSession(email: string, password: string): Promise<Models.Session>;\n createEmailPasswordSession(\n paramsOrFirst: { email: string, password: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Session> {\n let params: { email: string, password: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { email: string, password: string };\n } else {\n params = {\n email: paramsOrFirst as string,\n password: rest[0] as string \n };\n }\n\n const email = params.email;\n const password = params.password;\n\n if (typeof email === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"email\"');\n }\n\n if (typeof password === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"password\"');\n }\n\n const apiPath = '/account/sessions/email';\n const payload: Payload = {};\n\n if (typeof email !== 'undefined') {\n payload['email'] = email;\n }\n\n if (typeof password !== 'undefined') {\n payload['password'] = password;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to create a session from token. Provide the **userId** and **secret** parameters from the successful response of authentication flows initiated by token creation. For example, magic URL and phone login.\n *\n * @param {string} params.userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} params.secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.6.0. Please use `Account.createSession` instead.\n */\n updateMagicURLSession(params: { userId: string, secret: string }): Promise<Models.Session>;\n /**\n * Use this endpoint to create a session from token. Provide the **userId** and **secret** parameters from the successful response of authentication flows initiated by token creation. For example, magic URL and phone login.\n *\n * @param {string} userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMagicURLSession(userId: string, secret: string): Promise<Models.Session>;\n updateMagicURLSession(\n paramsOrFirst: { userId: string, secret: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Session> {\n let params: { userId: string, secret: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, secret: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n secret: rest[0] as string \n };\n }\n\n const userId = params.userId;\n const secret = params.secret;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof secret === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"secret\"');\n }\n\n const apiPath = '/account/sessions/magic-url';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof secret !== 'undefined') {\n payload['secret'] = secret;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Allow the user to login to their account using the OAuth2 provider of their choice. Each OAuth2 provider should be enabled from the Appwrite console first. Use the success and failure arguments to provide a redirect URL's back to your app when login is completed.\n * \n * If there is already an active session, the new session will be attached to the logged-in account. If there are no active sessions, the server will attempt to look for a user with the same email address as the email received from the OAuth2 provider and attach the new session to the existing user. If no matching user is found - the server will create a new user.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n * \n *\n * @param {OAuthProvider} params.provider - OAuth2 Provider. Currently, supported providers are: amazon, apple, auth0, authentik, autodesk, bitbucket, bitly, box, dailymotion, discord, disqus, dropbox, etsy, facebook, figma, github, gitlab, google, linkedin, microsoft, notion, oidc, okta, paypal, paypalSandbox, podio, salesforce, slack, spotify, stripe, tradeshift, tradeshiftBox, twitch, wordpress, yahoo, yammer, yandex, zoho, zoom.\n * @param {string} params.success - URL to redirect back to your app after a successful login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string} params.failure - URL to redirect back to your app after a failed login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string[]} params.scopes - A list of custom OAuth2 scopes. Check each provider internal docs for a list of supported scopes. Maximum of 100 scopes are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {void|string}\n */\n createOAuth2Session(params: { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] }): void | URL;\n /**\n * Allow the user to login to their account using the OAuth2 provider of their choice. Each OAuth2 provider should be enabled from the Appwrite console first. Use the success and failure arguments to provide a redirect URL's back to your app when login is completed.\n * \n * If there is already an active session, the new session will be attached to the logged-in account. If there are no active sessions, the server will attempt to look for a user with the same email address as the email received from the OAuth2 provider and attach the new session to the existing user. If no matching user is found - the server will create a new user.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n * \n *\n * @param {OAuthProvider} provider - OAuth2 Provider. Currently, supported providers are: amazon, apple, auth0, authentik, autodesk, bitbucket, bitly, box, dailymotion, discord, disqus, dropbox, etsy, facebook, figma, github, gitlab, google, linkedin, microsoft, notion, oidc, okta, paypal, paypalSandbox, podio, salesforce, slack, spotify, stripe, tradeshift, tradeshiftBox, twitch, wordpress, yahoo, yammer, yandex, zoho, zoom.\n * @param {string} success - URL to redirect back to your app after a successful login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string} failure - URL to redirect back to your app after a failed login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string[]} scopes - A list of custom OAuth2 scopes. Check each provider internal docs for a list of supported scopes. Maximum of 100 scopes are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {void | URL}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createOAuth2Session(provider: OAuthProvider, success?: string, failure?: string, scopes?: string[]): void | URL;\n createOAuth2Session(\n paramsOrFirst: { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] } | OAuthProvider,\n ...rest: [(string)?, (string)?, (string[])?] \n ): void | URL {\n let params: { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'provider' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] };\n } else {\n params = {\n provider: paramsOrFirst as OAuthProvider,\n success: rest[0] as string,\n failure: rest[1] as string,\n scopes: rest[2] as string[] \n };\n }\n\n const provider = params.provider;\n const success = params.success;\n const failure = params.failure;\n const scopes = params.scopes;\n\n if (typeof provider === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"provider\"');\n }\n\n const apiPath = '/account/sessions/oauth2/{provider}'.replace('{provider}', provider);\n const payload: Payload = {};\n\n if (typeof success !== 'undefined') {\n payload['success'] = success;\n }\n\n if (typeof failure !== 'undefined') {\n payload['failure'] = failure;\n }\n\n if (typeof scopes !== 'undefined') {\n payload['scopes'] = scopes;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return uri;\n }\n\n /**\n * Use this endpoint to create a session from token. Provide the **userId** and **secret** parameters from the successful response of authentication flows initiated by token creation. For example, magic URL and phone login.\n *\n * @param {string} params.userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} params.secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.6.0. Please use `Account.createSession` instead.\n */\n updatePhoneSession(params: { userId: string, secret: string }): Promise<Models.Session>;\n /**\n * Use this endpoint to create a session from token. Provide the **userId** and **secret** parameters from the successful response of authentication flows initiated by token creation. For example, magic URL and phone login.\n *\n * @param {string} userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updatePhoneSession(userId: string, secret: string): Promise<Models.Session>;\n updatePhoneSession(\n paramsOrFirst: { userId: string, secret: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Session> {\n let params: { userId: string, secret: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, secret: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n secret: rest[0] as string \n };\n }\n\n const userId = params.userId;\n const secret = params.secret;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof secret === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"secret\"');\n }\n\n const apiPath = '/account/sessions/phone';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof secret !== 'undefined') {\n payload['secret'] = secret;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to create a session from token. Provide the **userId** and **secret** parameters from the successful response of authentication flows initiated by token creation. For example, magic URL and phone login.\n *\n * @param {string} params.userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} params.secret - Secret of a token generated by login methods. For example, the `createMagicURLToken` or `createPhoneToken` methods.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createSession(params: { userId: string, secret: string }): Promise<Models.Session>;\n /**\n * Use this endpoint to create a session from token. Provide the **userId** and **secret** parameters from the successful response of authentication flows initiated by token creation. For example, magic URL and phone login.\n *\n * @param {string} userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} secret - Secret of a token generated by login methods. For example, the `createMagicURLToken` or `createPhoneToken` methods.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createSession(userId: string, secret: string): Promise<Models.Session>;\n createSession(\n paramsOrFirst: { userId: string, secret: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Session> {\n let params: { userId: string, secret: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, secret: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n secret: rest[0] as string \n };\n }\n\n const userId = params.userId;\n const secret = params.secret;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof secret === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"secret\"');\n }\n\n const apiPath = '/account/sessions/token';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof secret !== 'undefined') {\n payload['secret'] = secret;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to get a logged in user's session using a Session ID. Inputting 'current' will return the current session being used.\n *\n * @param {string} params.sessionId - Session ID. Use the string 'current' to get the current device session.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getSession(params: { sessionId: string }): Promise<Models.Session>;\n /**\n * Use this endpoint to get a logged in user's session using a Session ID. Inputting 'current' will return the current session being used.\n *\n * @param {string} sessionId - Session ID. Use the string 'current' to get the current device session.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getSession(sessionId: string): Promise<Models.Session>;\n getSession(\n paramsOrFirst: { sessionId: string } | string \n ): Promise<Models.Session> {\n let params: { sessionId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { sessionId: string };\n } else {\n params = {\n sessionId: paramsOrFirst as string \n };\n }\n\n const sessionId = params.sessionId;\n\n if (typeof sessionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"sessionId\"');\n }\n\n const apiPath = '/account/sessions/{sessionId}'.replace('{sessionId}', sessionId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Use this endpoint to extend a session's length. Extending a session is useful when session expiry is short. If the session was created using an OAuth provider, this endpoint refreshes the access token from the provider.\n *\n * @param {string} params.sessionId - Session ID. Use the string 'current' to update the current device session.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateSession(params: { sessionId: string }): Promise<Models.Session>;\n /**\n * Use this endpoint to extend a session's length. Extending a session is useful when session expiry is short. If the session was created using an OAuth provider, this endpoint refreshes the access token from the provider.\n *\n * @param {string} sessionId - Session ID. Use the string 'current' to update the current device session.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Session>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateSession(sessionId: string): Promise<Models.Session>;\n updateSession(\n paramsOrFirst: { sessionId: string } | string \n ): Promise<Models.Session> {\n let params: { sessionId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { sessionId: string };\n } else {\n params = {\n sessionId: paramsOrFirst as string \n };\n }\n\n const sessionId = params.sessionId;\n\n if (typeof sessionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"sessionId\"');\n }\n\n const apiPath = '/account/sessions/{sessionId}'.replace('{sessionId}', sessionId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Logout the user. Use 'current' as the session ID to logout on this device, use a session ID to logout on another device. If you're looking to logout the user on all devices, use [Delete Sessions](https://appwrite.io/docs/references/cloud/client-web/account#deleteSessions) instead.\n *\n * @param {string} params.sessionId - Session ID. Use the string 'current' to delete the current device session.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteSession(params: { sessionId: string }): Promise<{}>;\n /**\n * Logout the user. Use 'current' as the session ID to logout on this device, use a session ID to logout on another device. If you're looking to logout the user on all devices, use [Delete Sessions](https://appwrite.io/docs/references/cloud/client-web/account#deleteSessions) instead.\n *\n * @param {string} sessionId - Session ID. Use the string 'current' to delete the current device session.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteSession(sessionId: string): Promise<{}>;\n deleteSession(\n paramsOrFirst: { sessionId: string } | string \n ): Promise<{}> {\n let params: { sessionId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { sessionId: string };\n } else {\n params = {\n sessionId: paramsOrFirst as string \n };\n }\n\n const sessionId = params.sessionId;\n\n if (typeof sessionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"sessionId\"');\n }\n\n const apiPath = '/account/sessions/{sessionId}'.replace('{sessionId}', sessionId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Block the currently logged in user account. Behind the scene, the user record is not deleted but permanently blocked from any access. To completely delete a user, use the Users API instead.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateStatus<Preferences extends Models.Preferences = Models.DefaultPreferences>(): Promise<Models.User<Preferences>> {\n const apiPath = '/account/status';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to register a device for push notifications. Provide a target ID (custom or generated using ID.unique()), a device identifier (usually a device token), and optionally specify which provider should send notifications to this target. The target is automatically linked to the current session and includes device information like brand and model.\n *\n * @param {string} params.targetId - Target ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} params.identifier - The target identifier (token, email, phone etc.)\n * @param {string} params.providerId - Provider ID. Message will be sent to this target from the specified provider ID. If no provider ID is set the first setup provider will be used.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createPushTarget(params: { targetId: string, identifier: string, providerId?: string }): Promise<Models.Target>;\n /**\n * Use this endpoint to register a device for push notifications. Provide a target ID (custom or generated using ID.unique()), a device identifier (usually a device token), and optionally specify which provider should send notifications to this target. The target is automatically linked to the current session and includes device information like brand and model.\n *\n * @param {string} targetId - Target ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} identifier - The target identifier (token, email, phone etc.)\n * @param {string} providerId - Provider ID. Message will be sent to this target from the specified provider ID. If no provider ID is set the first setup provider will be used.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Target>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createPushTarget(targetId: string, identifier: string, providerId?: string): Promise<Models.Target>;\n createPushTarget(\n paramsOrFirst: { targetId: string, identifier: string, providerId?: string } | string,\n ...rest: [(string)?, (string)?] \n ): Promise<Models.Target> {\n let params: { targetId: string, identifier: string, providerId?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { targetId: string, identifier: string, providerId?: string };\n } else {\n params = {\n targetId: paramsOrFirst as string,\n identifier: rest[0] as string,\n providerId: rest[1] as string \n };\n }\n\n const targetId = params.targetId;\n const identifier = params.identifier;\n const providerId = params.providerId;\n\n if (typeof targetId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"targetId\"');\n }\n\n if (typeof identifier === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"identifier\"');\n }\n\n const apiPath = '/account/targets/push';\n const payload: Payload = {};\n\n if (typeof targetId !== 'undefined') {\n payload['targetId'] = targetId;\n }\n\n if (typeof identifier !== 'undefined') {\n payload['identifier'] = identifier;\n }\n\n if (typeof providerId !== 'undefined') {\n payload['providerId'] = providerId;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Update the currently logged in user's push notification target. You can modify the target's identifier (device token) and provider ID (token, email, phone etc.). The target must exist and belong to the current user. If you change the provider ID, notifications will be sent through the new messaging provider instead.\n *\n * @param {string} params.targetId - Target ID.\n * @param {string} params.identifier - The target identifier (token, email, phone etc.)\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updatePushTarget(params: { targetId: string, identifier: string }): Promise<Models.Target>;\n /**\n * Update the currently logged in user's push notification target. You can modify the target's identifier (device token) and provider ID (token, email, phone etc.). The target must exist and belong to the current user. If you change the provider ID, notifications will be sent through the new messaging provider instead.\n *\n * @param {string} targetId - Target ID.\n * @param {string} identifier - The target identifier (token, email, phone etc.)\n * @throws {AppwriteException}\n * @returns {Promise<Models.Target>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updatePushTarget(targetId: string, identifier: string): Promise<Models.Target>;\n updatePushTarget(\n paramsOrFirst: { targetId: string, identifier: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Target> {\n let params: { targetId: string, identifier: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { targetId: string, identifier: string };\n } else {\n params = {\n targetId: paramsOrFirst as string,\n identifier: rest[0] as string \n };\n }\n\n const targetId = params.targetId;\n const identifier = params.identifier;\n\n if (typeof targetId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"targetId\"');\n }\n\n if (typeof identifier === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"identifier\"');\n }\n\n const apiPath = '/account/targets/{targetId}/push'.replace('{targetId}', targetId);\n const payload: Payload = {};\n\n if (typeof identifier !== 'undefined') {\n payload['identifier'] = identifier;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete a push notification target for the currently logged in user. After deletion, the device will no longer receive push notifications. The target must exist and belong to the current user.\n *\n * @param {string} params.targetId - Target ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deletePushTarget(params: { targetId: string }): Promise<{}>;\n /**\n * Delete a push notification target for the currently logged in user. After deletion, the device will no longer receive push notifications. The target must exist and belong to the current user.\n *\n * @param {string} targetId - Target ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deletePushTarget(targetId: string): Promise<{}>;\n deletePushTarget(\n paramsOrFirst: { targetId: string } | string \n ): Promise<{}> {\n let params: { targetId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { targetId: string };\n } else {\n params = {\n targetId: paramsOrFirst as string \n };\n }\n\n const targetId = params.targetId;\n\n if (typeof targetId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"targetId\"');\n }\n\n const apiPath = '/account/targets/{targetId}/push'.replace('{targetId}', targetId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Sends the user an email with a secret key for creating a session. If the email address has never been used, a **new account is created** using the provided `userId`. Otherwise, if the email address is already attached to an account, the **user ID is ignored**. Then, the user will receive an email with the one-time password. Use the returned user ID and secret and submit a request to the [POST /v1/account/sessions/token](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint to complete the login process. The secret sent to the user's email is valid for 15 minutes.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n * \n *\n * @param {string} params.userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars. If the email address has never been used, a new account is created using the provided userId. Otherwise, if the email address is already attached to an account, the user ID is ignored.\n * @param {string} params.email - User email.\n * @param {boolean} params.phrase - Toggle for security phrase. If enabled, email will be send with a randomly generated phrase and the phrase will also be included in the response. Confirming phrases match increases the security of your authentication flow.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createEmailToken(params: { userId: string, email: string, phrase?: boolean }): Promise<Models.Token>;\n /**\n * Sends the user an email with a secret key for creating a session. If the email address has never been used, a **new account is created** using the provided `userId`. Otherwise, if the email address is already attached to an account, the **user ID is ignored**. Then, the user will receive an email with the one-time password. Use the returned user ID and secret and submit a request to the [POST /v1/account/sessions/token](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint to complete the login process. The secret sent to the user's email is valid for 15 minutes.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n * \n *\n * @param {string} userId - User ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars. If the email address has never been used, a new account is created using the provided userId. Otherwise, if the email address is already attached to an account, the user ID is ignored.\n * @param {string} email - User email.\n * @param {boolean} phrase - Toggle for security phrase. If enabled, email will be send with a randomly generated phrase and the phrase will also be included in the response. Confirming phrases match increases the security of your authentication flow.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createEmailToken(userId: string, email: string, phrase?: boolean): Promise<Models.Token>;\n createEmailToken(\n paramsOrFirst: { userId: string, email: string, phrase?: boolean } | string,\n ...rest: [(string)?, (boolean)?] \n ): Promise<Models.Token> {\n let params: { userId: string, email: string, phrase?: boolean };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, email: string, phrase?: boolean };\n } else {\n params = {\n userId: paramsOrFirst as string,\n email: rest[0] as string,\n phrase: rest[1] as boolean \n };\n }\n\n const userId = params.userId;\n const email = params.email;\n const phrase = params.phrase;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof email === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"email\"');\n }\n\n const apiPath = '/account/tokens/email';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof email !== 'undefined') {\n payload['email'] = email;\n }\n\n if (typeof phrase !== 'undefined') {\n payload['phrase'] = phrase;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Sends the user an email with a secret key for creating a session. If the provided user ID has not been registered, a new user will be created. When the user clicks the link in the email, the user is redirected back to the URL you provided with the secret key and userId values attached to the URL query string. Use the query string parameters to submit a request to the [POST /v1/account/sessions/token](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint to complete the login process. The link sent to the user's email address is valid for 1 hour.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n * \n *\n * @param {string} params.userId - Unique Id. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars. If the email address has never been used, a new account is created using the provided userId. Otherwise, if the email address is already attached to an account, the user ID is ignored.\n * @param {string} params.email - User email.\n * @param {string} params.url - URL to redirect the user back to your app from the magic URL login. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {boolean} params.phrase - Toggle for security phrase. If enabled, email will be send with a randomly generated phrase and the phrase will also be included in the response. Confirming phrases match increases the security of your authentication flow.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createMagicURLToken(params: { userId: string, email: string, url?: string, phrase?: boolean }): Promise<Models.Token>;\n /**\n * Sends the user an email with a secret key for creating a session. If the provided user ID has not been registered, a new user will be created. When the user clicks the link in the email, the user is redirected back to the URL you provided with the secret key and userId values attached to the URL query string. Use the query string parameters to submit a request to the [POST /v1/account/sessions/token](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint to complete the login process. The link sent to the user's email address is valid for 1 hour.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n * \n *\n * @param {string} userId - Unique Id. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars. If the email address has never been used, a new account is created using the provided userId. Otherwise, if the email address is already attached to an account, the user ID is ignored.\n * @param {string} email - User email.\n * @param {string} url - URL to redirect the user back to your app from the magic URL login. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {boolean} phrase - Toggle for security phrase. If enabled, email will be send with a randomly generated phrase and the phrase will also be included in the response. Confirming phrases match increases the security of your authentication flow.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createMagicURLToken(userId: string, email: string, url?: string, phrase?: boolean): Promise<Models.Token>;\n createMagicURLToken(\n paramsOrFirst: { userId: string, email: string, url?: string, phrase?: boolean } | string,\n ...rest: [(string)?, (string)?, (boolean)?] \n ): Promise<Models.Token> {\n let params: { userId: string, email: string, url?: string, phrase?: boolean };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, email: string, url?: string, phrase?: boolean };\n } else {\n params = {\n userId: paramsOrFirst as string,\n email: rest[0] as string,\n url: rest[1] as string,\n phrase: rest[2] as boolean \n };\n }\n\n const userId = params.userId;\n const email = params.email;\n const url = params.url;\n const phrase = params.phrase;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof email === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"email\"');\n }\n\n const apiPath = '/account/tokens/magic-url';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof email !== 'undefined') {\n payload['email'] = email;\n }\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n if (typeof phrase !== 'undefined') {\n payload['phrase'] = phrase;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Allow the user to login to their account using the OAuth2 provider of their choice. Each OAuth2 provider should be enabled from the Appwrite console first. Use the success and failure arguments to provide a redirect URL's back to your app when login is completed. \n * \n * If authentication succeeds, `userId` and `secret` of a token will be appended to the success URL as query parameters. These can be used to create a new session using the [Create session](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n *\n * @param {OAuthProvider} params.provider - OAuth2 Provider. Currently, supported providers are: amazon, apple, auth0, authentik, autodesk, bitbucket, bitly, box, dailymotion, discord, disqus, dropbox, etsy, facebook, figma, github, gitlab, google, linkedin, microsoft, notion, oidc, okta, paypal, paypalSandbox, podio, salesforce, slack, spotify, stripe, tradeshift, tradeshiftBox, twitch, wordpress, yahoo, yammer, yandex, zoho, zoom.\n * @param {string} params.success - URL to redirect back to your app after a successful login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string} params.failure - URL to redirect back to your app after a failed login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string[]} params.scopes - A list of custom OAuth2 scopes. Check each provider internal docs for a list of supported scopes. Maximum of 100 scopes are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {void|string}\n */\n createOAuth2Token(params: { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] }): void | URL;\n /**\n * Allow the user to login to their account using the OAuth2 provider of their choice. Each OAuth2 provider should be enabled from the Appwrite console first. Use the success and failure arguments to provide a redirect URL's back to your app when login is completed. \n * \n * If authentication succeeds, `userId` and `secret` of a token will be appended to the success URL as query parameters. These can be used to create a new session using the [Create session](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n *\n * @param {OAuthProvider} provider - OAuth2 Provider. Currently, supported providers are: amazon, apple, auth0, authentik, autodesk, bitbucket, bitly, box, dailymotion, discord, disqus, dropbox, etsy, facebook, figma, github, gitlab, google, linkedin, microsoft, notion, oidc, okta, paypal, paypalSandbox, podio, salesforce, slack, spotify, stripe, tradeshift, tradeshiftBox, twitch, wordpress, yahoo, yammer, yandex, zoho, zoom.\n * @param {string} success - URL to redirect back to your app after a successful login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string} failure - URL to redirect back to your app after a failed login attempt. Only URLs from hostnames in your project's platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string[]} scopes - A list of custom OAuth2 scopes. Check each provider internal docs for a list of supported scopes. Maximum of 100 scopes are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {void | URL}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createOAuth2Token(provider: OAuthProvider, success?: string, failure?: string, scopes?: string[]): void | URL;\n createOAuth2Token(\n paramsOrFirst: { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] } | OAuthProvider,\n ...rest: [(string)?, (string)?, (string[])?] \n ): void | URL {\n let params: { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'provider' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { provider: OAuthProvider, success?: string, failure?: string, scopes?: string[] };\n } else {\n params = {\n provider: paramsOrFirst as OAuthProvider,\n success: rest[0] as string,\n failure: rest[1] as string,\n scopes: rest[2] as string[] \n };\n }\n\n const provider = params.provider;\n const success = params.success;\n const failure = params.failure;\n const scopes = params.scopes;\n\n if (typeof provider === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"provider\"');\n }\n\n const apiPath = '/account/tokens/oauth2/{provider}'.replace('{provider}', provider);\n const payload: Payload = {};\n\n if (typeof success !== 'undefined') {\n payload['success'] = success;\n }\n\n if (typeof failure !== 'undefined') {\n payload['failure'] = failure;\n }\n\n if (typeof scopes !== 'undefined') {\n payload['scopes'] = scopes;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return uri;\n }\n\n /**\n * Sends the user an SMS with a secret key for creating a session. If the provided user ID has not be registered, a new user will be created. Use the returned user ID and secret and submit a request to the [POST /v1/account/sessions/token](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint to complete the login process. The secret sent to the user's phone is valid for 15 minutes.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n *\n * @param {string} params.userId - Unique Id. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars. If the phone number has never been used, a new account is created using the provided userId. Otherwise, if the phone number is already attached to an account, the user ID is ignored.\n * @param {string} params.phone - Phone number. Format this number with a leading '+' and a country code, e.g., +16175551212.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createPhoneToken(params: { userId: string, phone: string }): Promise<Models.Token>;\n /**\n * Sends the user an SMS with a secret key for creating a session. If the provided user ID has not be registered, a new user will be created. Use the returned user ID and secret and submit a request to the [POST /v1/account/sessions/token](https://appwrite.io/docs/references/cloud/client-web/account#createSession) endpoint to complete the login process. The secret sent to the user's phone is valid for 15 minutes.\n * \n * A user is limited to 10 active sessions at a time by default. [Learn more about session limits](https://appwrite.io/docs/authentication-security#limits).\n *\n * @param {string} userId - Unique Id. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars. If the phone number has never been used, a new account is created using the provided userId. Otherwise, if the phone number is already attached to an account, the user ID is ignored.\n * @param {string} phone - Phone number. Format this number with a leading '+' and a country code, e.g., +16175551212.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createPhoneToken(userId: string, phone: string): Promise<Models.Token>;\n createPhoneToken(\n paramsOrFirst: { userId: string, phone: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Token> {\n let params: { userId: string, phone: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, phone: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n phone: rest[0] as string \n };\n }\n\n const userId = params.userId;\n const phone = params.phone;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof phone === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"phone\"');\n }\n\n const apiPath = '/account/tokens/phone';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof phone !== 'undefined') {\n payload['phone'] = phone;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to send a verification message to your user email address to confirm they are the valid owners of that address. Both the **userId** and **secret** arguments will be passed as query parameters to the URL you have provided to be attached to the verification email. The provided URL should redirect the user back to your app and allow you to complete the verification process by verifying both the **userId** and **secret** parameters. Learn more about how to [complete the verification process](https://appwrite.io/docs/references/cloud/client-web/account#updateVerification). The verification link sent to the user's email address is valid for 7 days.\n * \n * Please note that in order to avoid a [Redirect Attack](https://github.com/OWASP/CheatSheetSeries/blob/master/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.md), the only valid redirect URLs are the ones from domains you have set when adding your platforms in the console interface.\n * \n *\n * @param {string} params.url - URL to redirect the user back to your app from the verification email. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createVerification(params: { url: string }): Promise<Models.Token>;\n /**\n * Use this endpoint to send a verification message to your user email address to confirm they are the valid owners of that address. Both the **userId** and **secret** arguments will be passed as query parameters to the URL you have provided to be attached to the verification email. The provided URL should redirect the user back to your app and allow you to complete the verification process by verifying both the **userId** and **secret** parameters. Learn more about how to [complete the verification process](https://appwrite.io/docs/references/cloud/client-web/account#updateVerification). The verification link sent to the user's email address is valid for 7 days.\n * \n * Please note that in order to avoid a [Redirect Attack](https://github.com/OWASP/CheatSheetSeries/blob/master/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.md), the only valid redirect URLs are the ones from domains you have set when adding your platforms in the console interface.\n * \n *\n * @param {string} url - URL to redirect the user back to your app from the verification email. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createVerification(url: string): Promise<Models.Token>;\n createVerification(\n paramsOrFirst: { url: string } | string \n ): Promise<Models.Token> {\n let params: { url: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { url: string };\n } else {\n params = {\n url: paramsOrFirst as string \n };\n }\n\n const url = params.url;\n\n if (typeof url === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"url\"');\n }\n\n const apiPath = '/account/verification';\n const payload: Payload = {};\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to complete the user email verification process. Use both the **userId** and **secret** parameters that were attached to your app URL to verify the user email ownership. If confirmed this route will return a 200 status code.\n *\n * @param {string} params.userId - User ID.\n * @param {string} params.secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateVerification(params: { userId: string, secret: string }): Promise<Models.Token>;\n /**\n * Use this endpoint to complete the user email verification process. Use both the **userId** and **secret** parameters that were attached to your app URL to verify the user email ownership. If confirmed this route will return a 200 status code.\n *\n * @param {string} userId - User ID.\n * @param {string} secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateVerification(userId: string, secret: string): Promise<Models.Token>;\n updateVerification(\n paramsOrFirst: { userId: string, secret: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Token> {\n let params: { userId: string, secret: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, secret: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n secret: rest[0] as string \n };\n }\n\n const userId = params.userId;\n const secret = params.secret;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof secret === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"secret\"');\n }\n\n const apiPath = '/account/verification';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof secret !== 'undefined') {\n payload['secret'] = secret;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to send a verification SMS to the currently logged in user. This endpoint is meant for use after updating a user's phone number using the [accountUpdatePhone](https://appwrite.io/docs/references/cloud/client-web/account#updatePhone) endpoint. Learn more about how to [complete the verification process](https://appwrite.io/docs/references/cloud/client-web/account#updatePhoneVerification). The verification code sent to the user's phone number is valid for 15 minutes.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createPhoneVerification(): Promise<Models.Token> {\n const apiPath = '/account/verification/phone';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to complete the user phone verification process. Use the **userId** and **secret** that were sent to your user's phone number to verify the user email ownership. If confirmed this route will return a 200 status code.\n *\n * @param {string} params.userId - User ID.\n * @param {string} params.secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updatePhoneVerification(params: { userId: string, secret: string }): Promise<Models.Token>;\n /**\n * Use this endpoint to complete the user phone verification process. Use the **userId** and **secret** that were sent to your user's phone number to verify the user email ownership. If confirmed this route will return a 200 status code.\n *\n * @param {string} userId - User ID.\n * @param {string} secret - Valid verification token.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Token>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updatePhoneVerification(userId: string, secret: string): Promise<Models.Token>;\n updatePhoneVerification(\n paramsOrFirst: { userId: string, secret: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Token> {\n let params: { userId: string, secret: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { userId: string, secret: string };\n } else {\n params = {\n userId: paramsOrFirst as string,\n secret: rest[0] as string \n };\n }\n\n const userId = params.userId;\n const secret = params.secret;\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof secret === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"secret\"');\n }\n\n const apiPath = '/account/verification/phone';\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof secret !== 'undefined') {\n payload['secret'] = secret;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\nimport { Browser } from '../enums/browser';\nimport { CreditCard } from '../enums/credit-card';\nimport { Flag } from '../enums/flag';\n\nexport class Avatars extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * You can use this endpoint to show different browser icons to your users. The code argument receives the browser code as it appears in your user [GET /account/sessions](https://appwrite.io/docs/references/cloud/client-web/account#getSessions) endpoint. Use width, height and quality arguments to change the output settings.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n *\n * @param {Browser} params.code - Browser Code.\n * @param {number} params.width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} params.height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} params.quality - Image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getBrowser(params: { code: Browser, width?: number, height?: number, quality?: number }): Promise<ArrayBuffer>;\n /**\n * You can use this endpoint to show different browser icons to your users. The code argument receives the browser code as it appears in your user [GET /account/sessions](https://appwrite.io/docs/references/cloud/client-web/account#getSessions) endpoint. Use width, height and quality arguments to change the output settings.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n *\n * @param {Browser} code - Browser Code.\n * @param {number} width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} quality - Image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getBrowser(code: Browser, width?: number, height?: number, quality?: number): Promise<ArrayBuffer>;\n getBrowser(\n paramsOrFirst: { code: Browser, width?: number, height?: number, quality?: number } | Browser,\n ...rest: [(number)?, (number)?, (number)?] \n ): Promise<ArrayBuffer> {\n let params: { code: Browser, width?: number, height?: number, quality?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'code' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { code: Browser, width?: number, height?: number, quality?: number };\n } else {\n params = {\n code: paramsOrFirst as Browser,\n width: rest[0] as number,\n height: rest[1] as number,\n quality: rest[2] as number \n };\n }\n\n const code = params.code;\n const width = params.width;\n const height = params.height;\n const quality = params.quality;\n\n if (typeof code === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"code\"');\n }\n\n const apiPath = '/avatars/browsers/{code}'.replace('{code}', code);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * The credit card endpoint will return you the icon of the credit card provider you need. Use width, height and quality arguments to change the output settings.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n * \n *\n * @param {CreditCard} params.code - Credit Card Code. Possible values: amex, argencard, cabal, cencosud, diners, discover, elo, hipercard, jcb, mastercard, naranja, targeta-shopping, unionpay, visa, mir, maestro, rupay.\n * @param {number} params.width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} params.height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} params.quality - Image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getCreditCard(params: { code: CreditCard, width?: number, height?: number, quality?: number }): Promise<ArrayBuffer>;\n /**\n * The credit card endpoint will return you the icon of the credit card provider you need. Use width, height and quality arguments to change the output settings.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n * \n *\n * @param {CreditCard} code - Credit Card Code. Possible values: amex, argencard, cabal, cencosud, diners, discover, elo, hipercard, jcb, mastercard, naranja, targeta-shopping, unionpay, visa, mir, maestro, rupay.\n * @param {number} width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} quality - Image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getCreditCard(code: CreditCard, width?: number, height?: number, quality?: number): Promise<ArrayBuffer>;\n getCreditCard(\n paramsOrFirst: { code: CreditCard, width?: number, height?: number, quality?: number } | CreditCard,\n ...rest: [(number)?, (number)?, (number)?] \n ): Promise<ArrayBuffer> {\n let params: { code: CreditCard, width?: number, height?: number, quality?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'code' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { code: CreditCard, width?: number, height?: number, quality?: number };\n } else {\n params = {\n code: paramsOrFirst as CreditCard,\n width: rest[0] as number,\n height: rest[1] as number,\n quality: rest[2] as number \n };\n }\n\n const code = params.code;\n const width = params.width;\n const height = params.height;\n const quality = params.quality;\n\n if (typeof code === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"code\"');\n }\n\n const apiPath = '/avatars/credit-cards/{code}'.replace('{code}', code);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * Use this endpoint to fetch the favorite icon (AKA favicon) of any remote website URL.\n * \n * This endpoint does not follow HTTP redirects.\n *\n * @param {string} params.url - Website URL which you want to fetch the favicon from.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getFavicon(params: { url: string }): Promise<ArrayBuffer>;\n /**\n * Use this endpoint to fetch the favorite icon (AKA favicon) of any remote website URL.\n * \n * This endpoint does not follow HTTP redirects.\n *\n * @param {string} url - Website URL which you want to fetch the favicon from.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getFavicon(url: string): Promise<ArrayBuffer>;\n getFavicon(\n paramsOrFirst: { url: string } | string \n ): Promise<ArrayBuffer> {\n let params: { url: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { url: string };\n } else {\n params = {\n url: paramsOrFirst as string \n };\n }\n\n const url = params.url;\n\n if (typeof url === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"url\"');\n }\n\n const apiPath = '/avatars/favicon';\n const payload: Payload = {};\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * You can use this endpoint to show different country flags icons to your users. The code argument receives the 2 letter country code. Use width, height and quality arguments to change the output settings. Country codes follow the [ISO 3166-1](https://en.wikipedia.org/wiki/ISO_3166-1) standard.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n * \n *\n * @param {Flag} params.code - Country Code. ISO Alpha-2 country code format.\n * @param {number} params.width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} params.height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} params.quality - Image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getFlag(params: { code: Flag, width?: number, height?: number, quality?: number }): Promise<ArrayBuffer>;\n /**\n * You can use this endpoint to show different country flags icons to your users. The code argument receives the 2 letter country code. Use width, height and quality arguments to change the output settings. Country codes follow the [ISO 3166-1](https://en.wikipedia.org/wiki/ISO_3166-1) standard.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n * \n *\n * @param {Flag} code - Country Code. ISO Alpha-2 country code format.\n * @param {number} width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} quality - Image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getFlag(code: Flag, width?: number, height?: number, quality?: number): Promise<ArrayBuffer>;\n getFlag(\n paramsOrFirst: { code: Flag, width?: number, height?: number, quality?: number } | Flag,\n ...rest: [(number)?, (number)?, (number)?] \n ): Promise<ArrayBuffer> {\n let params: { code: Flag, width?: number, height?: number, quality?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'code' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { code: Flag, width?: number, height?: number, quality?: number };\n } else {\n params = {\n code: paramsOrFirst as Flag,\n width: rest[0] as number,\n height: rest[1] as number,\n quality: rest[2] as number \n };\n }\n\n const code = params.code;\n const width = params.width;\n const height = params.height;\n const quality = params.quality;\n\n if (typeof code === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"code\"');\n }\n\n const apiPath = '/avatars/flags/{code}'.replace('{code}', code);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * Use this endpoint to fetch a remote image URL and crop it to any image size you want. This endpoint is very useful if you need to crop and display remote images in your app or in case you want to make sure a 3rd party image is properly served using a TLS protocol.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 400x400px.\n * \n * This endpoint does not follow HTTP redirects.\n *\n * @param {string} params.url - Image URL which you want to crop.\n * @param {number} params.width - Resize preview image width, Pass an integer between 0 to 2000. Defaults to 400.\n * @param {number} params.height - Resize preview image height, Pass an integer between 0 to 2000. Defaults to 400.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getImage(params: { url: string, width?: number, height?: number }): Promise<ArrayBuffer>;\n /**\n * Use this endpoint to fetch a remote image URL and crop it to any image size you want. This endpoint is very useful if you need to crop and display remote images in your app or in case you want to make sure a 3rd party image is properly served using a TLS protocol.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 400x400px.\n * \n * This endpoint does not follow HTTP redirects.\n *\n * @param {string} url - Image URL which you want to crop.\n * @param {number} width - Resize preview image width, Pass an integer between 0 to 2000. Defaults to 400.\n * @param {number} height - Resize preview image height, Pass an integer between 0 to 2000. Defaults to 400.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getImage(url: string, width?: number, height?: number): Promise<ArrayBuffer>;\n getImage(\n paramsOrFirst: { url: string, width?: number, height?: number } | string,\n ...rest: [(number)?, (number)?] \n ): Promise<ArrayBuffer> {\n let params: { url: string, width?: number, height?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { url: string, width?: number, height?: number };\n } else {\n params = {\n url: paramsOrFirst as string,\n width: rest[0] as number,\n height: rest[1] as number \n };\n }\n\n const url = params.url;\n const width = params.width;\n const height = params.height;\n\n if (typeof url === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"url\"');\n }\n\n const apiPath = '/avatars/image';\n const payload: Payload = {};\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * Use this endpoint to show your user initials avatar icon on your website or app. By default, this route will try to print your logged-in user name or email initials. You can also overwrite the user name if you pass the 'name' parameter. If no name is given and no user is logged, an empty avatar will be returned.\n * \n * You can use the color and background params to change the avatar colors. By default, a random theme will be selected. The random theme will persist for the user's initials when reloading the same theme will always return for the same initials.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n * \n *\n * @param {string} params.name - Full Name. When empty, current user name or email will be used. Max length: 128 chars.\n * @param {number} params.width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} params.height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {string} params.background - Changes background color. By default a random color will be picked and stay will persistent to the given name.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getInitials(params?: { name?: string, width?: number, height?: number, background?: string }): Promise<ArrayBuffer>;\n /**\n * Use this endpoint to show your user initials avatar icon on your website or app. By default, this route will try to print your logged-in user name or email initials. You can also overwrite the user name if you pass the 'name' parameter. If no name is given and no user is logged, an empty avatar will be returned.\n * \n * You can use the color and background params to change the avatar colors. By default, a random theme will be selected. The random theme will persist for the user's initials when reloading the same theme will always return for the same initials.\n * \n * When one dimension is specified and the other is 0, the image is scaled with preserved aspect ratio. If both dimensions are 0, the API provides an image at source quality. If dimensions are not specified, the default size of image returned is 100x100px.\n * \n *\n * @param {string} name - Full Name. When empty, current user name or email will be used. Max length: 128 chars.\n * @param {number} width - Image width. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {number} height - Image height. Pass an integer between 0 to 2000. Defaults to 100.\n * @param {string} background - Changes background color. By default a random color will be picked and stay will persistent to the given name.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getInitials(name?: string, width?: number, height?: number, background?: string): Promise<ArrayBuffer>;\n getInitials(\n paramsOrFirst?: { name?: string, width?: number, height?: number, background?: string } | string,\n ...rest: [(number)?, (number)?, (string)?] \n ): Promise<ArrayBuffer> {\n let params: { name?: string, width?: number, height?: number, background?: string };\n\n if (!paramsOrFirst || (paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { name?: string, width?: number, height?: number, background?: string };\n } else {\n params = {\n name: paramsOrFirst as string,\n width: rest[0] as number,\n height: rest[1] as number,\n background: rest[2] as string \n };\n }\n\n const name = params.name;\n const width = params.width;\n const height = params.height;\n const background = params.background;\n\n const apiPath = '/avatars/initials';\n const payload: Payload = {};\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof background !== 'undefined') {\n payload['background'] = background;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * Converts a given plain text to a QR code image. You can use the query parameters to change the size and style of the resulting image.\n * \n *\n * @param {string} params.text - Plain text to be converted to QR code image.\n * @param {number} params.size - QR code size. Pass an integer between 1 to 1000. Defaults to 400.\n * @param {number} params.margin - Margin from edge. Pass an integer between 0 to 10. Defaults to 1.\n * @param {boolean} params.download - Return resulting image with 'Content-Disposition: attachment ' headers for the browser to start downloading it. Pass 0 for no header, or 1 for otherwise. Default value is set to 0.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getQR(params: { text: string, size?: number, margin?: number, download?: boolean }): Promise<ArrayBuffer>;\n /**\n * Converts a given plain text to a QR code image. You can use the query parameters to change the size and style of the resulting image.\n * \n *\n * @param {string} text - Plain text to be converted to QR code image.\n * @param {number} size - QR code size. Pass an integer between 1 to 1000. Defaults to 400.\n * @param {number} margin - Margin from edge. Pass an integer between 0 to 10. Defaults to 1.\n * @param {boolean} download - Return resulting image with 'Content-Disposition: attachment ' headers for the browser to start downloading it. Pass 0 for no header, or 1 for otherwise. Default value is set to 0.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getQR(text: string, size?: number, margin?: number, download?: boolean): Promise<ArrayBuffer>;\n getQR(\n paramsOrFirst: { text: string, size?: number, margin?: number, download?: boolean } | string,\n ...rest: [(number)?, (number)?, (boolean)?] \n ): Promise<ArrayBuffer> {\n let params: { text: string, size?: number, margin?: number, download?: boolean };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { text: string, size?: number, margin?: number, download?: boolean };\n } else {\n params = {\n text: paramsOrFirst as string,\n size: rest[0] as number,\n margin: rest[1] as number,\n download: rest[2] as boolean \n };\n }\n\n const text = params.text;\n const size = params.size;\n const margin = params.margin;\n const download = params.download;\n\n if (typeof text === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"text\"');\n }\n\n const apiPath = '/avatars/qr';\n const payload: Payload = {};\n\n if (typeof text !== 'undefined') {\n payload['text'] = text;\n }\n\n if (typeof size !== 'undefined') {\n payload['size'] = size;\n }\n\n if (typeof margin !== 'undefined') {\n payload['margin'] = margin;\n }\n\n if (typeof download !== 'undefined') {\n payload['download'] = download;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * You can use this endpoint to show different browser icons to your users.\n * The code argument receives the browser code as it appears in your user [GET\n * /account/sessions](https://appwrite.io/docs/references/cloud/client-web/account#getSessions)\n * endpoint. Use width, height and quality arguments to change the output\n * settings.\n * \n * When one dimension is specified and the other is 0, the image is scaled\n * with preserved aspect ratio. If both dimensions are 0, the API provides an\n * image at source quality. If dimensions are not specified, the default size\n * of image returned is 100x100px.\n *\n * @param {Browser} code\n * @param {number} width\n * @param {number} height\n * @param {number} quality\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getBrowserURL(code: Browser, width?: number, height?: number, quality?: number): URL {\n const apiPath = '/avatars/browsers/{code}'.replace('{code}', code);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * The credit card endpoint will return you the icon of the credit card\n * provider you need. Use width, height and quality arguments to change the\n * output settings.\n * \n * When one dimension is specified and the other is 0, the image is scaled\n * with preserved aspect ratio. If both dimensions are 0, the API provides an\n * image at source quality. If dimensions are not specified, the default size\n * of image returned is 100x100px.\n * \n *\n * @param {CreditCard} code\n * @param {number} width\n * @param {number} height\n * @param {number} quality\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getCreditCardURL(code: CreditCard, width?: number, height?: number, quality?: number): URL {\n const apiPath = '/avatars/credit-cards/{code}'.replace('{code}', code);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * Use this endpoint to fetch the favorite icon (AKA favicon) of any remote\n * website URL.\n * \n * This endpoint does not follow HTTP redirects.\n *\n * @param {string} url\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getFaviconURL(url: string): URL {\n const apiPath = '/avatars/favicon';\n const payload: Payload = {};\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * You can use this endpoint to show different country flags icons to your\n * users. The code argument receives the 2 letter country code. Use width,\n * height and quality arguments to change the output settings. Country codes\n * follow the [ISO 3166-1](https://en.wikipedia.org/wiki/ISO_3166-1) standard.\n * \n * When one dimension is specified and the other is 0, the image is scaled\n * with preserved aspect ratio. If both dimensions are 0, the API provides an\n * image at source quality. If dimensions are not specified, the default size\n * of image returned is 100x100px.\n * \n *\n * @param {Flag} code\n * @param {number} width\n * @param {number} height\n * @param {number} quality\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getFlagURL(code: Flag, width?: number, height?: number, quality?: number): URL {\n const apiPath = '/avatars/flags/{code}'.replace('{code}', code);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * Use this endpoint to fetch a remote image URL and crop it to any image size\n * you want. This endpoint is very useful if you need to crop and display\n * remote images in your app or in case you want to make sure a 3rd party\n * image is properly served using a TLS protocol.\n * \n * When one dimension is specified and the other is 0, the image is scaled\n * with preserved aspect ratio. If both dimensions are 0, the API provides an\n * image at source quality. If dimensions are not specified, the default size\n * of image returned is 400x400px.\n * \n * This endpoint does not follow HTTP redirects.\n *\n * @param {string} url\n * @param {number} width\n * @param {number} height\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getImageURL(url: string, width?: number, height?: number): URL {\n const apiPath = '/avatars/image';\n const payload: Payload = {};\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * Use this endpoint to show your user initials avatar icon on your website or\n * app. By default, this route will try to print your logged-in user name or\n * email initials. You can also overwrite the user name if you pass the 'name'\n * parameter. If no name is given and no user is logged, an empty avatar will\n * be returned.\n * \n * You can use the color and background params to change the avatar colors. By\n * default, a random theme will be selected. The random theme will persist for\n * the user's initials when reloading the same theme will always return for\n * the same initials.\n * \n * When one dimension is specified and the other is 0, the image is scaled\n * with preserved aspect ratio. If both dimensions are 0, the API provides an\n * image at source quality. If dimensions are not specified, the default size\n * of image returned is 100x100px.\n * \n *\n * @param {string} name\n * @param {number} width\n * @param {number} height\n * @param {string} background\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getInitialsURL(name?: string, width?: number, height?: number, background?: string): URL {\n const apiPath = '/avatars/initials';\n const payload: Payload = {};\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof background !== 'undefined') {\n payload['background'] = background;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * Converts a given plain text to a QR code image. You can use the query\n * parameters to change the size and style of the resulting image.\n * \n *\n * @param {string} text\n * @param {number} size\n * @param {number} margin\n * @param {boolean} download\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getQRURL(text: string, size?: number, margin?: number, download?: boolean): URL {\n const apiPath = '/avatars/qr';\n const payload: Payload = {};\n\n if (typeof text !== 'undefined') {\n payload['text'] = text;\n }\n\n if (typeof size !== 'undefined') {\n payload['size'] = size;\n }\n\n if (typeof margin !== 'undefined') {\n payload['margin'] = margin;\n }\n\n if (typeof download !== 'undefined') {\n payload['download'] = download;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\n\nexport class Databases extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Get a list of all the user's documents in a given collection. You can use the query params to filter your results.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection).\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.listRows` instead.\n */\n listDocuments<Document extends Models.Document = Models.DefaultDocument>(params: { databaseId: string, collectionId: string, queries?: string[] }): Promise<Models.DocumentList<Document>>;\n /**\n * Get a list of all the user's documents in a given collection. You can use the query params to filter your results.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection).\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise<Models.DocumentList<Document>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n listDocuments<Document extends Models.Document = Models.DefaultDocument>(databaseId: string, collectionId: string, queries?: string[]): Promise<Models.DocumentList<Document>>;\n listDocuments<Document extends Models.Document = Models.DefaultDocument>(\n paramsOrFirst: { databaseId: string, collectionId: string, queries?: string[] } | string,\n ...rest: [(string)?, (string[])?] \n ): Promise<Models.DocumentList<Document>> {\n let params: { databaseId: string, collectionId: string, queries?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, queries?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n queries: rest[1] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const queries = params.queries;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId);\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Create a new Document. Before using this route, you should create a new collection resource using either a [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection) API or directly from your database console.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection). Make sure to define attributes before creating documents.\n * @param {string} params.documentId - Document ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>} params.data - Document data as JSON object.\n * @param {string[]} params.permissions - An array of permissions strings. By default, only the current user is granted all permissions. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.createRow` instead.\n */\n createDocument<Document extends Models.Document = Models.DefaultDocument>(params: { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>, permissions?: string[] }): Promise<Document>;\n /**\n * Create a new Document. Before using this route, you should create a new collection resource using either a [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection) API or directly from your database console.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection). Make sure to define attributes before creating documents.\n * @param {string} documentId - Document ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>} data - Document data as JSON object.\n * @param {string[]} permissions - An array of permissions strings. By default, only the current user is granted all permissions. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Document>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createDocument<Document extends Models.Document = Models.DefaultDocument>(databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>, permissions?: string[]): Promise<Document>;\n createDocument<Document extends Models.Document = Models.DefaultDocument>(\n paramsOrFirst: { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>, permissions?: string[] } | string,\n ...rest: [(string)?, (string)?, (Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>)?, (string[])?] \n ): Promise<Document> {\n let params: { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>, permissions?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>, permissions?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n documentId: rest[1] as string,\n data: rest[2] as Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Omit<Document, keyof Models.Document>,\n permissions: rest[3] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const documentId = params.documentId;\n const data = params.data;\n const permissions = params.permissions;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n if (typeof documentId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"documentId\"');\n }\n\n if (typeof data === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"data\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId);\n const payload: Payload = {};\n\n if (typeof documentId !== 'undefined') {\n payload['documentId'] = documentId;\n }\n\n if (typeof data !== 'undefined') {\n payload['data'] = data;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get a document by its unique ID. This endpoint response returns a JSON object with the document data.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection).\n * @param {string} params.documentId - Document ID.\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.getRow` instead.\n */\n getDocument<Document extends Models.Document = Models.DefaultDocument>(params: { databaseId: string, collectionId: string, documentId: string, queries?: string[] }): Promise<Document>;\n /**\n * Get a document by its unique ID. This endpoint response returns a JSON object with the document data.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection).\n * @param {string} documentId - Document ID.\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise<Document>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getDocument<Document extends Models.Document = Models.DefaultDocument>(databaseId: string, collectionId: string, documentId: string, queries?: string[]): Promise<Document>;\n getDocument<Document extends Models.Document = Models.DefaultDocument>(\n paramsOrFirst: { databaseId: string, collectionId: string, documentId: string, queries?: string[] } | string,\n ...rest: [(string)?, (string)?, (string[])?] \n ): Promise<Document> {\n let params: { databaseId: string, collectionId: string, documentId: string, queries?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, documentId: string, queries?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n documentId: rest[1] as string,\n queries: rest[2] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const documentId = params.documentId;\n const queries = params.queries;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n if (typeof documentId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"documentId\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents/{documentId}'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId).replace('{documentId}', documentId);\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Create or update a Document. Before using this route, you should create a new collection resource using either a [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection) API or directly from your database console.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID.\n * @param {string} params.documentId - Document ID.\n * @param {Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>} params.data - Document data as JSON object. Include all required attributes of the document to be created or updated.\n * @param {string[]} params.permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.upsertRow` instead.\n */\n upsertDocument<Document extends Models.Document = Models.DefaultDocument>(params: { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] }): Promise<Document>;\n /**\n * Create or update a Document. Before using this route, you should create a new collection resource using either a [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection) API or directly from your database console.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID.\n * @param {string} documentId - Document ID.\n * @param {Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>} data - Document data as JSON object. Include all required attributes of the document to be created or updated.\n * @param {string[]} permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Document>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n upsertDocument<Document extends Models.Document = Models.DefaultDocument>(databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[]): Promise<Document>;\n upsertDocument<Document extends Models.Document = Models.DefaultDocument>(\n paramsOrFirst: { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] } | string,\n ...rest: [(string)?, (string)?, (Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>)?, (string[])?] \n ): Promise<Document> {\n let params: { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, documentId: string, data: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n documentId: rest[1] as string,\n data: rest[2] as Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>,\n permissions: rest[3] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const documentId = params.documentId;\n const data = params.data;\n const permissions = params.permissions;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n if (typeof documentId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"documentId\"');\n }\n\n if (typeof data === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"data\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents/{documentId}'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId).replace('{documentId}', documentId);\n const payload: Payload = {};\n\n if (typeof data !== 'undefined') {\n payload['data'] = data;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Update a document by its unique ID. Using the patch method you can pass only specific fields that will get updated.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID.\n * @param {string} params.documentId - Document ID.\n * @param {Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>} params.data - Document data as JSON object. Include only attribute and value pairs to be updated.\n * @param {string[]} params.permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.updateRow` instead.\n */\n updateDocument<Document extends Models.Document = Models.DefaultDocument>(params: { databaseId: string, collectionId: string, documentId: string, data?: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] }): Promise<Document>;\n /**\n * Update a document by its unique ID. Using the patch method you can pass only specific fields that will get updated.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID.\n * @param {string} documentId - Document ID.\n * @param {Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>} data - Document data as JSON object. Include only attribute and value pairs to be updated.\n * @param {string[]} permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Document>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateDocument<Document extends Models.Document = Models.DefaultDocument>(databaseId: string, collectionId: string, documentId: string, data?: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[]): Promise<Document>;\n updateDocument<Document extends Models.Document = Models.DefaultDocument>(\n paramsOrFirst: { databaseId: string, collectionId: string, documentId: string, data?: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] } | string,\n ...rest: [(string)?, (string)?, (Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>)?, (string[])?] \n ): Promise<Document> {\n let params: { databaseId: string, collectionId: string, documentId: string, data?: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, documentId: string, data?: Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>, permissions?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n documentId: rest[1] as string,\n data: rest[2] as Document extends Models.DefaultDocument ? Partial<Models.Document> & Record<string, any> : Partial<Models.Document> & Partial<Omit<Document, keyof Models.Document>>,\n permissions: rest[3] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const documentId = params.documentId;\n const data = params.data;\n const permissions = params.permissions;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n if (typeof documentId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"documentId\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents/{documentId}'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId).replace('{documentId}', documentId);\n const payload: Payload = {};\n\n if (typeof data !== 'undefined') {\n payload['data'] = data;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete a document by its unique ID.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection).\n * @param {string} params.documentId - Document ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.deleteRow` instead.\n */\n deleteDocument(params: { databaseId: string, collectionId: string, documentId: string }): Promise<{}>;\n /**\n * Delete a document by its unique ID.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID. You can create a new collection using the Database service [server integration](https://appwrite.io/docs/server/databases#databasesCreateCollection).\n * @param {string} documentId - Document ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteDocument(databaseId: string, collectionId: string, documentId: string): Promise<{}>;\n deleteDocument(\n paramsOrFirst: { databaseId: string, collectionId: string, documentId: string } | string,\n ...rest: [(string)?, (string)?] \n ): Promise<{}> {\n let params: { databaseId: string, collectionId: string, documentId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, documentId: string };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n documentId: rest[1] as string \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const documentId = params.documentId;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n if (typeof documentId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"documentId\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents/{documentId}'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId).replace('{documentId}', documentId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Decrement a specific attribute of a document by a given value.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID.\n * @param {string} params.documentId - Document ID.\n * @param {string} params.attribute - Attribute key.\n * @param {number} params.value - Value to increment the attribute by. The value must be a number.\n * @param {number} params.min - Minimum value for the attribute. If the current value is lesser than this value, an exception will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.decrementRowColumn` instead.\n */\n decrementDocumentAttribute<Document extends Models.Document = Models.DefaultDocument>(params: { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, min?: number }): Promise<Document>;\n /**\n * Decrement a specific attribute of a document by a given value.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID.\n * @param {string} documentId - Document ID.\n * @param {string} attribute - Attribute key.\n * @param {number} value - Value to increment the attribute by. The value must be a number.\n * @param {number} min - Minimum value for the attribute. If the current value is lesser than this value, an exception will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise<Document>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n decrementDocumentAttribute<Document extends Models.Document = Models.DefaultDocument>(databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, min?: number): Promise<Document>;\n decrementDocumentAttribute<Document extends Models.Document = Models.DefaultDocument>(\n paramsOrFirst: { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, min?: number } | string,\n ...rest: [(string)?, (string)?, (string)?, (number)?, (number)?] \n ): Promise<Document> {\n let params: { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, min?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, min?: number };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n documentId: rest[1] as string,\n attribute: rest[2] as string,\n value: rest[3] as number,\n min: rest[4] as number \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const documentId = params.documentId;\n const attribute = params.attribute;\n const value = params.value;\n const min = params.min;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n if (typeof documentId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"documentId\"');\n }\n\n if (typeof attribute === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"attribute\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents/{documentId}/{attribute}/decrement'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId).replace('{documentId}', documentId).replace('{attribute}', attribute);\n const payload: Payload = {};\n\n if (typeof value !== 'undefined') {\n payload['value'] = value;\n }\n\n if (typeof min !== 'undefined') {\n payload['min'] = min;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Increment a specific attribute of a document by a given value.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.collectionId - Collection ID.\n * @param {string} params.documentId - Document ID.\n * @param {string} params.attribute - Attribute key.\n * @param {number} params.value - Value to increment the attribute by. The value must be a number.\n * @param {number} params.max - Maximum value for the attribute. If the current value is greater than this value, an error will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise}\n * @deprecated This API has been deprecated since 1.8.0. Please use `TablesDB.incrementRowColumn` instead.\n */\n incrementDocumentAttribute<Document extends Models.Document = Models.DefaultDocument>(params: { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, max?: number }): Promise<Document>;\n /**\n * Increment a specific attribute of a document by a given value.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} collectionId - Collection ID.\n * @param {string} documentId - Document ID.\n * @param {string} attribute - Attribute key.\n * @param {number} value - Value to increment the attribute by. The value must be a number.\n * @param {number} max - Maximum value for the attribute. If the current value is greater than this value, an error will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise<Document>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n incrementDocumentAttribute<Document extends Models.Document = Models.DefaultDocument>(databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, max?: number): Promise<Document>;\n incrementDocumentAttribute<Document extends Models.Document = Models.DefaultDocument>(\n paramsOrFirst: { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, max?: number } | string,\n ...rest: [(string)?, (string)?, (string)?, (number)?, (number)?] \n ): Promise<Document> {\n let params: { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, max?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, collectionId: string, documentId: string, attribute: string, value?: number, max?: number };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n collectionId: rest[0] as string,\n documentId: rest[1] as string,\n attribute: rest[2] as string,\n value: rest[3] as number,\n max: rest[4] as number \n };\n }\n\n const databaseId = params.databaseId;\n const collectionId = params.collectionId;\n const documentId = params.documentId;\n const attribute = params.attribute;\n const value = params.value;\n const max = params.max;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof collectionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"collectionId\"');\n }\n\n if (typeof documentId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"documentId\"');\n }\n\n if (typeof attribute === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"attribute\"');\n }\n\n const apiPath = '/databases/{databaseId}/collections/{collectionId}/documents/{documentId}/{attribute}/increment'.replace('{databaseId}', databaseId).replace('{collectionId}', collectionId).replace('{documentId}', documentId).replace('{attribute}', attribute);\n const payload: Payload = {};\n\n if (typeof value !== 'undefined') {\n payload['value'] = value;\n }\n\n if (typeof max !== 'undefined') {\n payload['max'] = max;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\nimport { ExecutionMethod } from '../enums/execution-method';\n\nexport class Functions extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Get a list of all the current user function execution logs. You can use the query params to filter your results.\n *\n * @param {string} params.functionId - Function ID.\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: trigger, status, responseStatusCode, duration, requestMethod, requestPath, deploymentId\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listExecutions(params: { functionId: string, queries?: string[] }): Promise<Models.ExecutionList>;\n /**\n * Get a list of all the current user function execution logs. You can use the query params to filter your results.\n *\n * @param {string} functionId - Function ID.\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: trigger, status, responseStatusCode, duration, requestMethod, requestPath, deploymentId\n * @throws {AppwriteException}\n * @returns {Promise<Models.ExecutionList>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n listExecutions(functionId: string, queries?: string[]): Promise<Models.ExecutionList>;\n listExecutions(\n paramsOrFirst: { functionId: string, queries?: string[] } | string,\n ...rest: [(string[])?] \n ): Promise<Models.ExecutionList> {\n let params: { functionId: string, queries?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { functionId: string, queries?: string[] };\n } else {\n params = {\n functionId: paramsOrFirst as string,\n queries: rest[0] as string[] \n };\n }\n\n const functionId = params.functionId;\n const queries = params.queries;\n\n if (typeof functionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"functionId\"');\n }\n\n const apiPath = '/functions/{functionId}/executions'.replace('{functionId}', functionId);\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Trigger a function execution. The returned object will return you the current execution status. You can ping the `Get Execution` endpoint to get updates on the current execution status. Once this endpoint is called, your function execution process will start asynchronously.\n *\n * @param {string} params.functionId - Function ID.\n * @param {string} params.body - HTTP body of execution. Default value is empty string.\n * @param {boolean} params.async - Execute code in the background. Default value is false.\n * @param {string} params.xpath - HTTP path of execution. Path can include query params. Default value is /\n * @param {ExecutionMethod} params.method - HTTP method of execution. Default value is POST.\n * @param {object} params.headers - HTTP headers of execution. Defaults to empty.\n * @param {string} params.scheduledAt - Scheduled execution time in [ISO 8601](https://www.iso.org/iso-8601-date-and-time-format.html) format. DateTime value must be in future with precision in minutes.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createExecution(params: { functionId: string, body?: string, async?: boolean, xpath?: string, method?: ExecutionMethod, headers?: object, scheduledAt?: string }): Promise<Models.Execution>;\n /**\n * Trigger a function execution. The returned object will return you the current execution status. You can ping the `Get Execution` endpoint to get updates on the current execution status. Once this endpoint is called, your function execution process will start asynchronously.\n *\n * @param {string} functionId - Function ID.\n * @param {string} body - HTTP body of execution. Default value is empty string.\n * @param {boolean} async - Execute code in the background. Default value is false.\n * @param {string} xpath - HTTP path of execution. Path can include query params. Default value is /\n * @param {ExecutionMethod} method - HTTP method of execution. Default value is POST.\n * @param {object} headers - HTTP headers of execution. Defaults to empty.\n * @param {string} scheduledAt - Scheduled execution time in [ISO 8601](https://www.iso.org/iso-8601-date-and-time-format.html) format. DateTime value must be in future with precision in minutes.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Execution>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createExecution(functionId: string, body?: string, async?: boolean, xpath?: string, method?: ExecutionMethod, headers?: object, scheduledAt?: string): Promise<Models.Execution>;\n createExecution(\n paramsOrFirst: { functionId: string, body?: string, async?: boolean, xpath?: string, method?: ExecutionMethod, headers?: object, scheduledAt?: string } | string,\n ...rest: [(string)?, (boolean)?, (string)?, (ExecutionMethod)?, (object)?, (string)?] \n ): Promise<Models.Execution> {\n let params: { functionId: string, body?: string, async?: boolean, xpath?: string, method?: ExecutionMethod, headers?: object, scheduledAt?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { functionId: string, body?: string, async?: boolean, xpath?: string, method?: ExecutionMethod, headers?: object, scheduledAt?: string };\n } else {\n params = {\n functionId: paramsOrFirst as string,\n body: rest[0] as string,\n async: rest[1] as boolean,\n xpath: rest[2] as string,\n method: rest[3] as ExecutionMethod,\n headers: rest[4] as object,\n scheduledAt: rest[5] as string \n };\n }\n\n const functionId = params.functionId;\n const body = params.body;\n const async = params.async;\n const xpath = params.xpath;\n const method = params.method;\n const headers = params.headers;\n const scheduledAt = params.scheduledAt;\n\n if (typeof functionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"functionId\"');\n }\n\n const apiPath = '/functions/{functionId}/executions'.replace('{functionId}', functionId);\n const payload: Payload = {};\n\n if (typeof body !== 'undefined') {\n payload['body'] = body;\n }\n\n if (typeof async !== 'undefined') {\n payload['async'] = async;\n }\n\n if (typeof xpath !== 'undefined') {\n payload['path'] = xpath;\n }\n\n if (typeof method !== 'undefined') {\n payload['method'] = method;\n }\n\n if (typeof headers !== 'undefined') {\n payload['headers'] = headers;\n }\n\n if (typeof scheduledAt !== 'undefined') {\n payload['scheduledAt'] = scheduledAt;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get a function execution log by its unique ID.\n *\n * @param {string} params.functionId - Function ID.\n * @param {string} params.executionId - Execution ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getExecution(params: { functionId: string, executionId: string }): Promise<Models.Execution>;\n /**\n * Get a function execution log by its unique ID.\n *\n * @param {string} functionId - Function ID.\n * @param {string} executionId - Execution ID.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Execution>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getExecution(functionId: string, executionId: string): Promise<Models.Execution>;\n getExecution(\n paramsOrFirst: { functionId: string, executionId: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Execution> {\n let params: { functionId: string, executionId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { functionId: string, executionId: string };\n } else {\n params = {\n functionId: paramsOrFirst as string,\n executionId: rest[0] as string \n };\n }\n\n const functionId = params.functionId;\n const executionId = params.executionId;\n\n if (typeof functionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"functionId\"');\n }\n\n if (typeof executionId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"executionId\"');\n }\n\n const apiPath = '/functions/{functionId}/executions/{executionId}'.replace('{functionId}', functionId).replace('{executionId}', executionId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\n\nexport class Graphql extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Execute a GraphQL mutation.\n *\n * @param {object} params.query - The query or queries to execute.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n query(params: { query: object }): Promise<{}>;\n /**\n * Execute a GraphQL mutation.\n *\n * @param {object} query - The query or queries to execute.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n query(query: object): Promise<{}>;\n query(\n paramsOrFirst: { query: object } | object \n ): Promise<{}> {\n let params: { query: object };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'query' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { query: object };\n } else {\n params = {\n query: paramsOrFirst as object \n };\n }\n\n const query = params.query;\n\n if (typeof query === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"query\"');\n }\n\n const apiPath = '/graphql';\n const payload: Payload = {};\n\n if (typeof query !== 'undefined') {\n payload['query'] = query;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'x-sdk-graphql': 'true',\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Execute a GraphQL mutation.\n *\n * @param {object} params.query - The query or queries to execute.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n mutation(params: { query: object }): Promise<{}>;\n /**\n * Execute a GraphQL mutation.\n *\n * @param {object} query - The query or queries to execute.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n mutation(query: object): Promise<{}>;\n mutation(\n paramsOrFirst: { query: object } | object \n ): Promise<{}> {\n let params: { query: object };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst) && 'query' in paramsOrFirst)) {\n params = (paramsOrFirst || {}) as { query: object };\n } else {\n params = {\n query: paramsOrFirst as object \n };\n }\n\n const query = params.query;\n\n if (typeof query === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"query\"');\n }\n\n const apiPath = '/graphql/mutation';\n const payload: Payload = {};\n\n if (typeof query !== 'undefined') {\n payload['query'] = query;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'x-sdk-graphql': 'true',\n 'content-type': 'application/json',\n }, payload);\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\n\nexport class Locale extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Get the current user location based on IP. Returns an object with user country code, country name, continent name, continent code, ip address and suggested currency. You can use the locale header to get the data in a supported language.\n * \n * ([IP Geolocation by DB-IP](https://db-ip.com))\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n get(): Promise<Models.Locale> {\n const apiPath = '/locale';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List of all locale codes in [ISO 639-1](https://en.wikipedia.org/wiki/List_of_ISO_639-1_codes).\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listCodes(): Promise<Models.LocaleCodeList> {\n const apiPath = '/locale/codes';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List of all continents. You can use the locale header to get the data in a supported language.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listContinents(): Promise<Models.ContinentList> {\n const apiPath = '/locale/continents';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List of all countries. You can use the locale header to get the data in a supported language.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listCountries(): Promise<Models.CountryList> {\n const apiPath = '/locale/countries';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List of all countries that are currently members of the EU. You can use the locale header to get the data in a supported language.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listCountriesEU(): Promise<Models.CountryList> {\n const apiPath = '/locale/countries/eu';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List of all countries phone codes. You can use the locale header to get the data in a supported language.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listCountriesPhones(): Promise<Models.PhoneList> {\n const apiPath = '/locale/countries/phones';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List of all currencies, including currency symbol, name, plural, and decimal digits for all major and minor currencies. You can use the locale header to get the data in a supported language.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listCurrencies(): Promise<Models.CurrencyList> {\n const apiPath = '/locale/currencies';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * List of all languages classified by ISO 639-1 including 2-letter code, name in English, and name in the respective language.\n *\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listLanguages(): Promise<Models.LanguageList> {\n const apiPath = '/locale/languages';\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\n\nexport class Messaging extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Create a new subscriber.\n *\n * @param {string} params.topicId - Topic ID. The topic ID to subscribe to.\n * @param {string} params.subscriberId - Subscriber ID. Choose a custom Subscriber ID or a new Subscriber ID.\n * @param {string} params.targetId - Target ID. The target ID to link to the specified Topic ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createSubscriber(params: { topicId: string, subscriberId: string, targetId: string }): Promise<Models.Subscriber>;\n /**\n * Create a new subscriber.\n *\n * @param {string} topicId - Topic ID. The topic ID to subscribe to.\n * @param {string} subscriberId - Subscriber ID. Choose a custom Subscriber ID or a new Subscriber ID.\n * @param {string} targetId - Target ID. The target ID to link to the specified Topic ID.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Subscriber>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createSubscriber(topicId: string, subscriberId: string, targetId: string): Promise<Models.Subscriber>;\n createSubscriber(\n paramsOrFirst: { topicId: string, subscriberId: string, targetId: string } | string,\n ...rest: [(string)?, (string)?] \n ): Promise<Models.Subscriber> {\n let params: { topicId: string, subscriberId: string, targetId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { topicId: string, subscriberId: string, targetId: string };\n } else {\n params = {\n topicId: paramsOrFirst as string,\n subscriberId: rest[0] as string,\n targetId: rest[1] as string \n };\n }\n\n const topicId = params.topicId;\n const subscriberId = params.subscriberId;\n const targetId = params.targetId;\n\n if (typeof topicId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"topicId\"');\n }\n\n if (typeof subscriberId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"subscriberId\"');\n }\n\n if (typeof targetId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"targetId\"');\n }\n\n const apiPath = '/messaging/topics/{topicId}/subscribers'.replace('{topicId}', topicId);\n const payload: Payload = {};\n\n if (typeof subscriberId !== 'undefined') {\n payload['subscriberId'] = subscriberId;\n }\n\n if (typeof targetId !== 'undefined') {\n payload['targetId'] = targetId;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete a subscriber by its unique ID.\n *\n * @param {string} params.topicId - Topic ID. The topic ID subscribed to.\n * @param {string} params.subscriberId - Subscriber ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteSubscriber(params: { topicId: string, subscriberId: string }): Promise<{}>;\n /**\n * Delete a subscriber by its unique ID.\n *\n * @param {string} topicId - Topic ID. The topic ID subscribed to.\n * @param {string} subscriberId - Subscriber ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteSubscriber(topicId: string, subscriberId: string): Promise<{}>;\n deleteSubscriber(\n paramsOrFirst: { topicId: string, subscriberId: string } | string,\n ...rest: [(string)?] \n ): Promise<{}> {\n let params: { topicId: string, subscriberId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { topicId: string, subscriberId: string };\n } else {\n params = {\n topicId: paramsOrFirst as string,\n subscriberId: rest[0] as string \n };\n }\n\n const topicId = params.topicId;\n const subscriberId = params.subscriberId;\n\n if (typeof topicId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"topicId\"');\n }\n\n if (typeof subscriberId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"subscriberId\"');\n }\n\n const apiPath = '/messaging/topics/{topicId}/subscribers/{subscriberId}'.replace('{topicId}', topicId).replace('{subscriberId}', subscriberId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\nimport { ImageGravity } from '../enums/image-gravity';\nimport { ImageFormat } from '../enums/image-format';\n\nexport class Storage extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Get a list of all the user files. You can use the query params to filter your results.\n *\n * @param {string} params.bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: name, signature, mimeType, sizeOriginal, chunksTotal, chunksUploaded\n * @param {string} params.search - Search term to filter your list results. Max length: 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listFiles(params: { bucketId: string, queries?: string[], search?: string }): Promise<Models.FileList>;\n /**\n * Get a list of all the user files. You can use the query params to filter your results.\n *\n * @param {string} bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: name, signature, mimeType, sizeOriginal, chunksTotal, chunksUploaded\n * @param {string} search - Search term to filter your list results. Max length: 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.FileList>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n listFiles(bucketId: string, queries?: string[], search?: string): Promise<Models.FileList>;\n listFiles(\n paramsOrFirst: { bucketId: string, queries?: string[], search?: string } | string,\n ...rest: [(string[])?, (string)?] \n ): Promise<Models.FileList> {\n let params: { bucketId: string, queries?: string[], search?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, queries?: string[], search?: string };\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n queries: rest[0] as string[],\n search: rest[1] as string \n };\n }\n\n const bucketId = params.bucketId;\n const queries = params.queries;\n const search = params.search;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files'.replace('{bucketId}', bucketId);\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n if (typeof search !== 'undefined') {\n payload['search'] = search;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Create a new file. Before using this route, you should create a new bucket resource using either a [server integration](https://appwrite.io/docs/server/storage#storageCreateBucket) API or directly from your Appwrite console.\n * \n * Larger files should be uploaded using multiple requests with the [content-range](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Range) header to send a partial request with a maximum supported chunk of `5MB`. The `content-range` header values should always be in bytes.\n * \n * When the first request is sent, the server will return the **File** object, and the subsequent part request must include the file's **id** in `x-appwrite-id` header to allow the server to know that the partial upload is for the existing file and not for a new one.\n * \n * If you're creating a new file using one of the Appwrite SDKs, all the chunking logic will be managed by the SDK internally.\n * \n *\n * @param {string} params.bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} params.fileId - File ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {{name: string, type: string, size: number, uri: string}} params.file - Binary file. Appwrite SDKs provide helpers to handle file input. [Learn about file input](https://appwrite.io/docs/products/storage/upload-download#input-file).\n * @param {string[]} params.permissions - An array of permission strings. By default, only the current user is granted all permissions. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n async createFile(params: { bucketId: string, fileId: string, file: {name: string, type: string, size: number, uri: string}, permissions?: string[] , onProgress?: (progress: UploadProgress) => void }): Promise<Models.File>;\n /**\n * Create a new file. Before using this route, you should create a new bucket resource using either a [server integration](https://appwrite.io/docs/server/storage#storageCreateBucket) API or directly from your Appwrite console.\n * \n * Larger files should be uploaded using multiple requests with the [content-range](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Range) header to send a partial request with a maximum supported chunk of `5MB`. The `content-range` header values should always be in bytes.\n * \n * When the first request is sent, the server will return the **File** object, and the subsequent part request must include the file's **id** in `x-appwrite-id` header to allow the server to know that the partial upload is for the existing file and not for a new one.\n * \n * If you're creating a new file using one of the Appwrite SDKs, all the chunking logic will be managed by the SDK internally.\n * \n *\n * @param {string} bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} fileId - File ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {{name: string, type: string, size: number, uri: string}} file - Binary file. Appwrite SDKs provide helpers to handle file input. [Learn about file input](https://appwrite.io/docs/products/storage/upload-download#input-file).\n * @param {string[]} permissions - An array of permission strings. By default, only the current user is granted all permissions. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Models.File>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n async createFile(bucketId: string, fileId: string, file: {name: string, type: string, size: number, uri: string}, permissions?: string[], onProgress?: (progress: UploadProgress) => void): Promise<Models.File>;\n async createFile(\n paramsOrFirst: { bucketId: string, fileId: string, file: {name: string, type: string, size: number, uri: string}, permissions?: string[], onProgress?: (progress: UploadProgress) => void } | string,\n ...rest: [(string)?, ({name: string, type: string, size: number, uri: string})?, (string[])?,((progress: UploadProgress) => void)?] \n ): Promise<Models.File> {\n let params: { bucketId: string, fileId: string, file: {name: string, type: string, size: number, uri: string}, permissions?: string[] };\n let onProgress: ((progress: UploadProgress) => void);\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, fileId: string, file: {name: string, type: string, size: number, uri: string}, permissions?: string[] };\n onProgress = paramsOrFirst?.onProgress as ((progress: UploadProgress) => void);\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n fileId: rest[0] as string,\n file: rest[1] as {name: string, type: string, size: number, uri: string},\n permissions: rest[2] as string[] \n };\n onProgress = rest[3] as ((progress: UploadProgress) => void);\n }\n\n const bucketId = params.bucketId;\n const fileId = params.fileId;\n const file = params.file;\n const permissions = params.permissions;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n if (typeof fileId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"fileId\"');\n }\n\n if (typeof file === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"file\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files'.replace('{bucketId}', bucketId);\n const payload: Payload = {};\n\n if (typeof fileId !== 'undefined') {\n payload['fileId'] = fileId;\n }\n\n if (typeof file !== 'undefined') {\n payload['file'] = file;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n\n const size = file.size;\n\n if (size <= Service.CHUNK_SIZE) {\n return this.client.call('post', uri, {\n 'content-type': 'multipart/form-data',\n }, payload);\n }\n\n const apiHeaders: { [header: string]: string } = {\n 'content-type': 'multipart/form-data',\n }\n\n let offset = 0;\n let response = undefined;\n try {\n response = await this.client.call('GET', new URL(this.client.config.endpoint + apiPath + '/' + fileId), apiHeaders);\n offset = response.chunksUploaded * Service.CHUNK_SIZE;\n } catch(e) {\n }\n\n let timestamp = new Date().getTime();\n while (offset < size) {\n let end = Math.min(offset + Service.CHUNK_SIZE - 1, size - 1);\n\n apiHeaders['content-range'] = 'bytes ' + offset + '-' + end + '/' + size;\n if (response && response.$id) {\n apiHeaders['x-appwrite-id'] = response.$id;\n }\n\n let chunk = await FileSystem.readAsStringAsync(file.uri, {\n encoding: FileSystem.EncodingType.Base64,\n position: offset,\n length: Service.CHUNK_SIZE\n });\n var path = `data:${file.type};base64,${chunk}`;\n if (Platform.OS.toLowerCase() === 'android') {\n path = FileSystem.cacheDirectory + '/tmp_chunk_' + timestamp;\n await FileSystem.writeAsStringAsync(path, chunk, {encoding: FileSystem.EncodingType.Base64});\n }\n\n payload['file'] = { uri: path, name: file.name, type: file.type };\n\n response = await this.client.call('post', uri, apiHeaders, payload);\n\n if (onProgress) {\n onProgress({\n $id: response.$id,\n progress: (offset / size) * 100,\n sizeUploaded: offset,\n chunksTotal: response.chunksTotal,\n chunksUploaded: response.chunksUploaded\n });\n }\n offset += Service.CHUNK_SIZE;\n }\n return response;\n }\n\n /**\n * Get a file by its unique ID. This endpoint response returns a JSON object with the file metadata.\n *\n * @param {string} params.bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} params.fileId - File ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getFile(params: { bucketId: string, fileId: string }): Promise<Models.File>;\n /**\n * Get a file by its unique ID. This endpoint response returns a JSON object with the file metadata.\n *\n * @param {string} bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} fileId - File ID.\n * @throws {AppwriteException}\n * @returns {Promise<Models.File>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getFile(bucketId: string, fileId: string): Promise<Models.File>;\n getFile(\n paramsOrFirst: { bucketId: string, fileId: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.File> {\n let params: { bucketId: string, fileId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, fileId: string };\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n fileId: rest[0] as string \n };\n }\n\n const bucketId = params.bucketId;\n const fileId = params.fileId;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n if (typeof fileId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"fileId\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Update a file by its unique ID. Only users with write permissions have access to update this resource.\n *\n * @param {string} params.bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} params.fileId - File unique ID.\n * @param {string} params.name - Name of the file\n * @param {string[]} params.permissions - An array of permission string. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateFile(params: { bucketId: string, fileId: string, name?: string, permissions?: string[] }): Promise<Models.File>;\n /**\n * Update a file by its unique ID. Only users with write permissions have access to update this resource.\n *\n * @param {string} bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} fileId - File unique ID.\n * @param {string} name - Name of the file\n * @param {string[]} permissions - An array of permission string. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Models.File>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateFile(bucketId: string, fileId: string, name?: string, permissions?: string[]): Promise<Models.File>;\n updateFile(\n paramsOrFirst: { bucketId: string, fileId: string, name?: string, permissions?: string[] } | string,\n ...rest: [(string)?, (string)?, (string[])?] \n ): Promise<Models.File> {\n let params: { bucketId: string, fileId: string, name?: string, permissions?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, fileId: string, name?: string, permissions?: string[] };\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n fileId: rest[0] as string,\n name: rest[1] as string,\n permissions: rest[2] as string[] \n };\n }\n\n const bucketId = params.bucketId;\n const fileId = params.fileId;\n const name = params.name;\n const permissions = params.permissions;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n if (typeof fileId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"fileId\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete a file by its unique ID. Only users with write permissions have access to delete this resource.\n *\n * @param {string} params.bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} params.fileId - File ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteFile(params: { bucketId: string, fileId: string }): Promise<{}>;\n /**\n * Delete a file by its unique ID. Only users with write permissions have access to delete this resource.\n *\n * @param {string} bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} fileId - File ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteFile(bucketId: string, fileId: string): Promise<{}>;\n deleteFile(\n paramsOrFirst: { bucketId: string, fileId: string } | string,\n ...rest: [(string)?] \n ): Promise<{}> {\n let params: { bucketId: string, fileId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, fileId: string };\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n fileId: rest[0] as string \n };\n }\n\n const bucketId = params.bucketId;\n const fileId = params.fileId;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n if (typeof fileId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"fileId\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get a file content by its unique ID. The endpoint response return with a 'Content-Disposition: attachment' header that tells the browser to start downloading the file to user downloads directory.\n *\n * @param {string} params.bucketId - Storage bucket ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} params.fileId - File ID.\n * @param {string} params.token - File token for accessing this file.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getFileDownload(params: { bucketId: string, fileId: string, token?: string }): Promise<ArrayBuffer>;\n /**\n * Get a file content by its unique ID. The endpoint response return with a 'Content-Disposition: attachment' header that tells the browser to start downloading the file to user downloads directory.\n *\n * @param {string} bucketId - Storage bucket ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} fileId - File ID.\n * @param {string} token - File token for accessing this file.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getFileDownload(bucketId: string, fileId: string, token?: string): Promise<ArrayBuffer>;\n getFileDownload(\n paramsOrFirst: { bucketId: string, fileId: string, token?: string } | string,\n ...rest: [(string)?, (string)?] \n ): Promise<ArrayBuffer> {\n let params: { bucketId: string, fileId: string, token?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, fileId: string, token?: string };\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n fileId: rest[0] as string,\n token: rest[1] as string \n };\n }\n\n const bucketId = params.bucketId;\n const fileId = params.fileId;\n const token = params.token;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n if (typeof fileId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"fileId\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}/download'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n if (typeof token !== 'undefined') {\n payload['token'] = token;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * Get a file preview image. Currently, this method supports preview for image files (jpg, png, and gif), other supported formats, like pdf, docs, slides, and spreadsheets, will return the file icon image. You can also pass query string arguments for cutting and resizing your preview image. Preview is supported only for image files smaller than 10MB.\n *\n * @param {string} params.bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} params.fileId - File ID\n * @param {number} params.width - Resize preview image width, Pass an integer between 0 to 4000.\n * @param {number} params.height - Resize preview image height, Pass an integer between 0 to 4000.\n * @param {ImageGravity} params.gravity - Image crop gravity. Can be one of center,top-left,top,top-right,left,right,bottom-left,bottom,bottom-right\n * @param {number} params.quality - Preview image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @param {number} params.borderWidth - Preview image border in pixels. Pass an integer between 0 to 100. Defaults to 0.\n * @param {string} params.borderColor - Preview image border color. Use a valid HEX color, no # is needed for prefix.\n * @param {number} params.borderRadius - Preview image border radius in pixels. Pass an integer between 0 to 4000.\n * @param {number} params.opacity - Preview image opacity. Only works with images having an alpha channel (like png). Pass a number between 0 to 1.\n * @param {number} params.rotation - Preview image rotation in degrees. Pass an integer between -360 and 360.\n * @param {string} params.background - Preview image background color. Only works with transparent images (png). Use a valid HEX color, no # is needed for prefix.\n * @param {ImageFormat} params.output - Output format type (jpeg, jpg, png, gif and webp).\n * @param {string} params.token - File token for accessing this file.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getFilePreview(params: { bucketId: string, fileId: string, width?: number, height?: number, gravity?: ImageGravity, quality?: number, borderWidth?: number, borderColor?: string, borderRadius?: number, opacity?: number, rotation?: number, background?: string, output?: ImageFormat, token?: string }): Promise<ArrayBuffer>;\n /**\n * Get a file preview image. Currently, this method supports preview for image files (jpg, png, and gif), other supported formats, like pdf, docs, slides, and spreadsheets, will return the file icon image. You can also pass query string arguments for cutting and resizing your preview image. Preview is supported only for image files smaller than 10MB.\n *\n * @param {string} bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} fileId - File ID\n * @param {number} width - Resize preview image width, Pass an integer between 0 to 4000.\n * @param {number} height - Resize preview image height, Pass an integer between 0 to 4000.\n * @param {ImageGravity} gravity - Image crop gravity. Can be one of center,top-left,top,top-right,left,right,bottom-left,bottom,bottom-right\n * @param {number} quality - Preview image quality. Pass an integer between 0 to 100. Defaults to keep existing image quality.\n * @param {number} borderWidth - Preview image border in pixels. Pass an integer between 0 to 100. Defaults to 0.\n * @param {string} borderColor - Preview image border color. Use a valid HEX color, no # is needed for prefix.\n * @param {number} borderRadius - Preview image border radius in pixels. Pass an integer between 0 to 4000.\n * @param {number} opacity - Preview image opacity. Only works with images having an alpha channel (like png). Pass a number between 0 to 1.\n * @param {number} rotation - Preview image rotation in degrees. Pass an integer between -360 and 360.\n * @param {string} background - Preview image background color. Only works with transparent images (png). Use a valid HEX color, no # is needed for prefix.\n * @param {ImageFormat} output - Output format type (jpeg, jpg, png, gif and webp).\n * @param {string} token - File token for accessing this file.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getFilePreview(bucketId: string, fileId: string, width?: number, height?: number, gravity?: ImageGravity, quality?: number, borderWidth?: number, borderColor?: string, borderRadius?: number, opacity?: number, rotation?: number, background?: string, output?: ImageFormat, token?: string): Promise<ArrayBuffer>;\n getFilePreview(\n paramsOrFirst: { bucketId: string, fileId: string, width?: number, height?: number, gravity?: ImageGravity, quality?: number, borderWidth?: number, borderColor?: string, borderRadius?: number, opacity?: number, rotation?: number, background?: string, output?: ImageFormat, token?: string } | string,\n ...rest: [(string)?, (number)?, (number)?, (ImageGravity)?, (number)?, (number)?, (string)?, (number)?, (number)?, (number)?, (string)?, (ImageFormat)?, (string)?] \n ): Promise<ArrayBuffer> {\n let params: { bucketId: string, fileId: string, width?: number, height?: number, gravity?: ImageGravity, quality?: number, borderWidth?: number, borderColor?: string, borderRadius?: number, opacity?: number, rotation?: number, background?: string, output?: ImageFormat, token?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, fileId: string, width?: number, height?: number, gravity?: ImageGravity, quality?: number, borderWidth?: number, borderColor?: string, borderRadius?: number, opacity?: number, rotation?: number, background?: string, output?: ImageFormat, token?: string };\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n fileId: rest[0] as string,\n width: rest[1] as number,\n height: rest[2] as number,\n gravity: rest[3] as ImageGravity,\n quality: rest[4] as number,\n borderWidth: rest[5] as number,\n borderColor: rest[6] as string,\n borderRadius: rest[7] as number,\n opacity: rest[8] as number,\n rotation: rest[9] as number,\n background: rest[10] as string,\n output: rest[11] as ImageFormat,\n token: rest[12] as string \n };\n }\n\n const bucketId = params.bucketId;\n const fileId = params.fileId;\n const width = params.width;\n const height = params.height;\n const gravity = params.gravity;\n const quality = params.quality;\n const borderWidth = params.borderWidth;\n const borderColor = params.borderColor;\n const borderRadius = params.borderRadius;\n const opacity = params.opacity;\n const rotation = params.rotation;\n const background = params.background;\n const output = params.output;\n const token = params.token;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n if (typeof fileId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"fileId\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}/preview'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof gravity !== 'undefined') {\n payload['gravity'] = gravity;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n if (typeof borderWidth !== 'undefined') {\n payload['borderWidth'] = borderWidth;\n }\n\n if (typeof borderColor !== 'undefined') {\n payload['borderColor'] = borderColor;\n }\n\n if (typeof borderRadius !== 'undefined') {\n payload['borderRadius'] = borderRadius;\n }\n\n if (typeof opacity !== 'undefined') {\n payload['opacity'] = opacity;\n }\n\n if (typeof rotation !== 'undefined') {\n payload['rotation'] = rotation;\n }\n\n if (typeof background !== 'undefined') {\n payload['background'] = background;\n }\n\n if (typeof output !== 'undefined') {\n payload['output'] = output;\n }\n\n if (typeof token !== 'undefined') {\n payload['token'] = token;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * Get a file content by its unique ID. This endpoint is similar to the download method but returns with no 'Content-Disposition: attachment' header.\n *\n * @param {string} params.bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} params.fileId - File ID.\n * @param {string} params.token - File token for accessing this file.\n * @throws {AppwriteException}\n * @returns {ArrayBuffer}\n */\n getFileView(params: { bucketId: string, fileId: string, token?: string }): Promise<ArrayBuffer>;\n /**\n * Get a file content by its unique ID. This endpoint is similar to the download method but returns with no 'Content-Disposition: attachment' header.\n *\n * @param {string} bucketId - Storage bucket unique ID. You can create a new storage bucket using the Storage service [server integration](https://appwrite.io/docs/server/storage#createBucket).\n * @param {string} fileId - File ID.\n * @param {string} token - File token for accessing this file.\n * @throws {AppwriteException}\n * @returns {Promise<ArrayBuffer>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getFileView(bucketId: string, fileId: string, token?: string): Promise<ArrayBuffer>;\n getFileView(\n paramsOrFirst: { bucketId: string, fileId: string, token?: string } | string,\n ...rest: [(string)?, (string)?] \n ): Promise<ArrayBuffer> {\n let params: { bucketId: string, fileId: string, token?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { bucketId: string, fileId: string, token?: string };\n } else {\n params = {\n bucketId: paramsOrFirst as string,\n fileId: rest[0] as string,\n token: rest[1] as string \n };\n }\n\n const bucketId = params.bucketId;\n const fileId = params.fileId;\n const token = params.token;\n\n if (typeof bucketId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"bucketId\"');\n }\n\n if (typeof fileId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"fileId\"');\n }\n\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}/view'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n if (typeof token !== 'undefined') {\n payload['token'] = token;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n return this.client.call('get', uri, {\n }, payload, 'arrayBuffer');\n }\n\n /**\n * Get a file content by its unique ID. The endpoint response return with a\n * 'Content-Disposition: attachment' header that tells the browser to start\n * downloading the file to user downloads directory.\n *\n * @param {string} bucketId\n * @param {string} fileId\n * @param {string} token\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getFileDownloadURL(bucketId: string, fileId: string, token?: string): URL {\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}/download'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n if (typeof token !== 'undefined') {\n payload['token'] = token;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * Get a file preview image. Currently, this method supports preview for image\n * files (jpg, png, and gif), other supported formats, like pdf, docs, slides,\n * and spreadsheets, will return the file icon image. You can also pass query\n * string arguments for cutting and resizing your preview image. Preview is\n * supported only for image files smaller than 10MB.\n *\n * @param {string} bucketId\n * @param {string} fileId\n * @param {number} width\n * @param {number} height\n * @param {ImageGravity} gravity\n * @param {number} quality\n * @param {number} borderWidth\n * @param {string} borderColor\n * @param {number} borderRadius\n * @param {number} opacity\n * @param {number} rotation\n * @param {string} background\n * @param {ImageFormat} output\n * @param {string} token\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getFilePreviewURL(bucketId: string, fileId: string, width?: number, height?: number, gravity?: ImageGravity, quality?: number, borderWidth?: number, borderColor?: string, borderRadius?: number, opacity?: number, rotation?: number, background?: string, output?: ImageFormat, token?: string): URL {\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}/preview'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n if (typeof width !== 'undefined') {\n payload['width'] = width;\n }\n\n if (typeof height !== 'undefined') {\n payload['height'] = height;\n }\n\n if (typeof gravity !== 'undefined') {\n payload['gravity'] = gravity;\n }\n\n if (typeof quality !== 'undefined') {\n payload['quality'] = quality;\n }\n\n if (typeof borderWidth !== 'undefined') {\n payload['borderWidth'] = borderWidth;\n }\n\n if (typeof borderColor !== 'undefined') {\n payload['borderColor'] = borderColor;\n }\n\n if (typeof borderRadius !== 'undefined') {\n payload['borderRadius'] = borderRadius;\n }\n\n if (typeof opacity !== 'undefined') {\n payload['opacity'] = opacity;\n }\n\n if (typeof rotation !== 'undefined') {\n payload['rotation'] = rotation;\n }\n\n if (typeof background !== 'undefined') {\n payload['background'] = background;\n }\n\n if (typeof output !== 'undefined') {\n payload['output'] = output;\n }\n\n if (typeof token !== 'undefined') {\n payload['token'] = token;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n\n /**\n * Get a file content by its unique ID. This endpoint is similar to the\n * download method but returns with no 'Content-Disposition: attachment'\n * header.\n *\n * @param {string} bucketId\n * @param {string} fileId\n * @param {string} token\n * @throws {AppwriteException}\n * @returns {URL}\n */\n getFileViewURL(bucketId: string, fileId: string, token?: string): URL {\n const apiPath = '/storage/buckets/{bucketId}/files/{fileId}/view'.replace('{bucketId}', bucketId).replace('{fileId}', fileId);\n const payload: Payload = {};\n\n if (typeof token !== 'undefined') {\n payload['token'] = token;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n payload['project'] = this.client.config.project;\n\n for (const [key, value] of Object.entries(Service.flatten(payload))) {\n uri.searchParams.append(key, value);\n }\n\n return uri;\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\n\nexport class TablesDB extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Get a list of all the user's rows in a given table. You can use the query params to filter your results.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID. You can create a new table using the TableDB service [server integration](https://appwrite.io/docs/server/tablesdbdb#tablesdbCreate).\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listRows<Row extends Models.Row = Models.DefaultRow>(params: { databaseId: string, tableId: string, queries?: string[] }): Promise<Models.RowList<Row>>;\n /**\n * Get a list of all the user's rows in a given table. You can use the query params to filter your results.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID. You can create a new table using the TableDB service [server integration](https://appwrite.io/docs/server/tablesdbdb#tablesdbCreate).\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise<Models.RowList<Row>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n listRows<Row extends Models.Row = Models.DefaultRow>(databaseId: string, tableId: string, queries?: string[]): Promise<Models.RowList<Row>>;\n listRows<Row extends Models.Row = Models.DefaultRow>(\n paramsOrFirst: { databaseId: string, tableId: string, queries?: string[] } | string,\n ...rest: [(string)?, (string[])?] \n ): Promise<Models.RowList<Row>> {\n let params: { databaseId: string, tableId: string, queries?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, queries?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n queries: rest[1] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const queries = params.queries;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows'.replace('{databaseId}', databaseId).replace('{tableId}', tableId);\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Create a new Row. Before using this route, you should create a new table resource using either a [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreateTable) API or directly from your database console.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID. You can create a new table using the Database service [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreate). Make sure to define columns before creating rows.\n * @param {string} params.rowId - Row ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>} params.data - Row data as JSON object.\n * @param {string[]} params.permissions - An array of permissions strings. By default, only the current user is granted all permissions. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createRow<Row extends Models.Row = Models.DefaultRow>(params: { databaseId: string, tableId: string, rowId: string, data: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>, permissions?: string[] }): Promise<Row>;\n /**\n * Create a new Row. Before using this route, you should create a new table resource using either a [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreateTable) API or directly from your database console.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID. You can create a new table using the Database service [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreate). Make sure to define columns before creating rows.\n * @param {string} rowId - Row ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>} data - Row data as JSON object.\n * @param {string[]} permissions - An array of permissions strings. By default, only the current user is granted all permissions. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Row>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createRow<Row extends Models.Row = Models.DefaultRow>(databaseId: string, tableId: string, rowId: string, data: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>, permissions?: string[]): Promise<Row>;\n createRow<Row extends Models.Row = Models.DefaultRow>(\n paramsOrFirst: { databaseId: string, tableId: string, rowId: string, data: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>, permissions?: string[] } | string,\n ...rest: [(string)?, (string)?, (Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>)?, (string[])?] \n ): Promise<Row> {\n let params: { databaseId: string, tableId: string, rowId: string, data: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>, permissions?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, rowId: string, data: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>, permissions?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n rowId: rest[1] as string,\n data: rest[2] as Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Omit<Row, keyof Models.Row>,\n permissions: rest[3] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const rowId = params.rowId;\n const data = params.data;\n const permissions = params.permissions;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n if (typeof rowId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"rowId\"');\n }\n\n if (typeof data === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"data\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows'.replace('{databaseId}', databaseId).replace('{tableId}', tableId);\n const payload: Payload = {};\n\n if (typeof rowId !== 'undefined') {\n payload['rowId'] = rowId;\n }\n\n if (typeof data !== 'undefined') {\n payload['data'] = data;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get a row by its unique ID. This endpoint response returns a JSON object with the row data.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID. You can create a new table using the Database service [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreate).\n * @param {string} params.rowId - Row ID.\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getRow<Row extends Models.Row = Models.DefaultRow>(params: { databaseId: string, tableId: string, rowId: string, queries?: string[] }): Promise<Row>;\n /**\n * Get a row by its unique ID. This endpoint response returns a JSON object with the row data.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID. You can create a new table using the Database service [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreate).\n * @param {string} rowId - Row ID.\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long.\n * @throws {AppwriteException}\n * @returns {Promise<Row>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getRow<Row extends Models.Row = Models.DefaultRow>(databaseId: string, tableId: string, rowId: string, queries?: string[]): Promise<Row>;\n getRow<Row extends Models.Row = Models.DefaultRow>(\n paramsOrFirst: { databaseId: string, tableId: string, rowId: string, queries?: string[] } | string,\n ...rest: [(string)?, (string)?, (string[])?] \n ): Promise<Row> {\n let params: { databaseId: string, tableId: string, rowId: string, queries?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, rowId: string, queries?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n rowId: rest[1] as string,\n queries: rest[2] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const rowId = params.rowId;\n const queries = params.queries;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n if (typeof rowId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"rowId\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows/{rowId}'.replace('{databaseId}', databaseId).replace('{tableId}', tableId).replace('{rowId}', rowId);\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Create or update a Row. Before using this route, you should create a new table resource using either a [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreateTable) API or directly from your database console.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID.\n * @param {string} params.rowId - Row ID.\n * @param {Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>} params.data - Row data as JSON object. Include all required columns of the row to be created or updated.\n * @param {string[]} params.permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n upsertRow<Row extends Models.Row = Models.DefaultRow>(params: { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] }): Promise<Row>;\n /**\n * Create or update a Row. Before using this route, you should create a new table resource using either a [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreateTable) API or directly from your database console.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID.\n * @param {string} rowId - Row ID.\n * @param {Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>} data - Row data as JSON object. Include all required columns of the row to be created or updated.\n * @param {string[]} permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Row>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n upsertRow<Row extends Models.Row = Models.DefaultRow>(databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[]): Promise<Row>;\n upsertRow<Row extends Models.Row = Models.DefaultRow>(\n paramsOrFirst: { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] } | string,\n ...rest: [(string)?, (string)?, (Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>)?, (string[])?] \n ): Promise<Row> {\n let params: { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n rowId: rest[1] as string,\n data: rest[2] as Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>,\n permissions: rest[3] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const rowId = params.rowId;\n const data = params.data;\n const permissions = params.permissions;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n if (typeof rowId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"rowId\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows/{rowId}'.replace('{databaseId}', databaseId).replace('{tableId}', tableId).replace('{rowId}', rowId);\n const payload: Payload = {};\n\n if (typeof data !== 'undefined') {\n payload['data'] = data;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Update a row by its unique ID. Using the patch method you can pass only specific fields that will get updated.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID.\n * @param {string} params.rowId - Row ID.\n * @param {Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>} params.data - Row data as JSON object. Include only columns and value pairs to be updated.\n * @param {string[]} params.permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateRow<Row extends Models.Row = Models.DefaultRow>(params: { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] }): Promise<Row>;\n /**\n * Update a row by its unique ID. Using the patch method you can pass only specific fields that will get updated.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID.\n * @param {string} rowId - Row ID.\n * @param {Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>} data - Row data as JSON object. Include only columns and value pairs to be updated.\n * @param {string[]} permissions - An array of permissions strings. By default, the current permissions are inherited. [Learn more about permissions](https://appwrite.io/docs/permissions).\n * @throws {AppwriteException}\n * @returns {Promise<Row>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateRow<Row extends Models.Row = Models.DefaultRow>(databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[]): Promise<Row>;\n updateRow<Row extends Models.Row = Models.DefaultRow>(\n paramsOrFirst: { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] } | string,\n ...rest: [(string)?, (string)?, (Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>)?, (string[])?] \n ): Promise<Row> {\n let params: { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, rowId: string, data?: Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>, permissions?: string[] };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n rowId: rest[1] as string,\n data: rest[2] as Row extends Models.DefaultRow ? Partial<Models.Row> & Record<string, any> : Partial<Models.Row> & Partial<Omit<Row, keyof Models.Row>>,\n permissions: rest[3] as string[] \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const rowId = params.rowId;\n const data = params.data;\n const permissions = params.permissions;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n if (typeof rowId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"rowId\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows/{rowId}'.replace('{databaseId}', databaseId).replace('{tableId}', tableId).replace('{rowId}', rowId);\n const payload: Payload = {};\n\n if (typeof data !== 'undefined') {\n payload['data'] = data;\n }\n\n if (typeof permissions !== 'undefined') {\n payload['permissions'] = permissions;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete a row by its unique ID.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID. You can create a new table using the Database service [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreate).\n * @param {string} params.rowId - Row ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteRow(params: { databaseId: string, tableId: string, rowId: string }): Promise<{}>;\n /**\n * Delete a row by its unique ID.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID. You can create a new table using the Database service [server integration](https://appwrite.io/docs/server/tablesdb#tablesDBCreate).\n * @param {string} rowId - Row ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteRow(databaseId: string, tableId: string, rowId: string): Promise<{}>;\n deleteRow(\n paramsOrFirst: { databaseId: string, tableId: string, rowId: string } | string,\n ...rest: [(string)?, (string)?] \n ): Promise<{}> {\n let params: { databaseId: string, tableId: string, rowId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, rowId: string };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n rowId: rest[1] as string \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const rowId = params.rowId;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n if (typeof rowId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"rowId\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows/{rowId}'.replace('{databaseId}', databaseId).replace('{tableId}', tableId).replace('{rowId}', rowId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Decrement a specific column of a row by a given value.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID.\n * @param {string} params.rowId - Row ID.\n * @param {string} params.column - Column key.\n * @param {number} params.value - Value to increment the column by. The value must be a number.\n * @param {number} params.min - Minimum value for the column. If the current value is lesser than this value, an exception will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n decrementRowColumn<Row extends Models.Row = Models.DefaultRow>(params: { databaseId: string, tableId: string, rowId: string, column: string, value?: number, min?: number }): Promise<Row>;\n /**\n * Decrement a specific column of a row by a given value.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID.\n * @param {string} rowId - Row ID.\n * @param {string} column - Column key.\n * @param {number} value - Value to increment the column by. The value must be a number.\n * @param {number} min - Minimum value for the column. If the current value is lesser than this value, an exception will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise<Row>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n decrementRowColumn<Row extends Models.Row = Models.DefaultRow>(databaseId: string, tableId: string, rowId: string, column: string, value?: number, min?: number): Promise<Row>;\n decrementRowColumn<Row extends Models.Row = Models.DefaultRow>(\n paramsOrFirst: { databaseId: string, tableId: string, rowId: string, column: string, value?: number, min?: number } | string,\n ...rest: [(string)?, (string)?, (string)?, (number)?, (number)?] \n ): Promise<Row> {\n let params: { databaseId: string, tableId: string, rowId: string, column: string, value?: number, min?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, rowId: string, column: string, value?: number, min?: number };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n rowId: rest[1] as string,\n column: rest[2] as string,\n value: rest[3] as number,\n min: rest[4] as number \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const rowId = params.rowId;\n const column = params.column;\n const value = params.value;\n const min = params.min;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n if (typeof rowId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"rowId\"');\n }\n\n if (typeof column === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"column\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows/{rowId}/{column}/decrement'.replace('{databaseId}', databaseId).replace('{tableId}', tableId).replace('{rowId}', rowId).replace('{column}', column);\n const payload: Payload = {};\n\n if (typeof value !== 'undefined') {\n payload['value'] = value;\n }\n\n if (typeof min !== 'undefined') {\n payload['min'] = min;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Increment a specific column of a row by a given value.\n *\n * @param {string} params.databaseId - Database ID.\n * @param {string} params.tableId - Table ID.\n * @param {string} params.rowId - Row ID.\n * @param {string} params.column - Column key.\n * @param {number} params.value - Value to increment the column by. The value must be a number.\n * @param {number} params.max - Maximum value for the column. If the current value is greater than this value, an error will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n incrementRowColumn<Row extends Models.Row = Models.DefaultRow>(params: { databaseId: string, tableId: string, rowId: string, column: string, value?: number, max?: number }): Promise<Row>;\n /**\n * Increment a specific column of a row by a given value.\n *\n * @param {string} databaseId - Database ID.\n * @param {string} tableId - Table ID.\n * @param {string} rowId - Row ID.\n * @param {string} column - Column key.\n * @param {number} value - Value to increment the column by. The value must be a number.\n * @param {number} max - Maximum value for the column. If the current value is greater than this value, an error will be thrown.\n * @throws {AppwriteException}\n * @returns {Promise<Row>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n incrementRowColumn<Row extends Models.Row = Models.DefaultRow>(databaseId: string, tableId: string, rowId: string, column: string, value?: number, max?: number): Promise<Row>;\n incrementRowColumn<Row extends Models.Row = Models.DefaultRow>(\n paramsOrFirst: { databaseId: string, tableId: string, rowId: string, column: string, value?: number, max?: number } | string,\n ...rest: [(string)?, (string)?, (string)?, (number)?, (number)?] \n ): Promise<Row> {\n let params: { databaseId: string, tableId: string, rowId: string, column: string, value?: number, max?: number };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { databaseId: string, tableId: string, rowId: string, column: string, value?: number, max?: number };\n } else {\n params = {\n databaseId: paramsOrFirst as string,\n tableId: rest[0] as string,\n rowId: rest[1] as string,\n column: rest[2] as string,\n value: rest[3] as number,\n max: rest[4] as number \n };\n }\n\n const databaseId = params.databaseId;\n const tableId = params.tableId;\n const rowId = params.rowId;\n const column = params.column;\n const value = params.value;\n const max = params.max;\n\n if (typeof databaseId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"databaseId\"');\n }\n\n if (typeof tableId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"tableId\"');\n }\n\n if (typeof rowId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"rowId\"');\n }\n\n if (typeof column === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"column\"');\n }\n\n const apiPath = '/tablesdb/{databaseId}/tables/{tableId}/rows/{rowId}/{column}/increment'.replace('{databaseId}', databaseId).replace('{tableId}', tableId).replace('{rowId}', rowId).replace('{column}', column);\n const payload: Payload = {};\n\n if (typeof value !== 'undefined') {\n payload['value'] = value;\n }\n\n if (typeof max !== 'undefined') {\n payload['max'] = max;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n};\n","import { Service } from '../service';\nimport { AppwriteException, Client } from '../client';\nimport type { Models } from '../models';\nimport type { UploadProgress, Payload } from '../client';\nimport * as FileSystem from 'expo-file-system';\nimport { Platform } from 'react-native';\n\n\nexport class Teams extends Service {\n\n constructor(client: Client)\n {\n super(client);\n }\n\n /**\n * Get a list of all the teams in which the current user is a member. You can use the parameters to filter your results.\n *\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: name, total, billingPlan\n * @param {string} params.search - Search term to filter your list results. Max length: 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n list<Preferences extends Models.Preferences = Models.DefaultPreferences>(params?: { queries?: string[], search?: string }): Promise<Models.TeamList<Preferences>>;\n /**\n * Get a list of all the teams in which the current user is a member. You can use the parameters to filter your results.\n *\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: name, total, billingPlan\n * @param {string} search - Search term to filter your list results. Max length: 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.TeamList<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n list<Preferences extends Models.Preferences = Models.DefaultPreferences>(queries?: string[], search?: string): Promise<Models.TeamList<Preferences>>;\n list<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst?: { queries?: string[], search?: string } | string[],\n ...rest: [(string)?] \n ): Promise<Models.TeamList<Preferences>> {\n let params: { queries?: string[], search?: string };\n\n if (!paramsOrFirst || (paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { queries?: string[], search?: string };\n } else {\n params = {\n queries: paramsOrFirst as string[],\n search: rest[0] as string \n };\n }\n\n const queries = params.queries;\n const search = params.search;\n\n const apiPath = '/teams';\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n if (typeof search !== 'undefined') {\n payload['search'] = search;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Create a new team. The user who creates the team will automatically be assigned as the owner of the team. Only the users with the owner role can invite new members, add new owners and delete or update the team.\n *\n * @param {string} params.teamId - Team ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} params.name - Team name. Max length: 128 chars.\n * @param {string[]} params.roles - Array of strings. Use this param to set the roles in the team for the user who created it. The default role is **owner**. A role can be any string. Learn more about [roles and permissions](https://appwrite.io/docs/permissions). Maximum of 100 roles are allowed, each 32 characters long.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n create<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { teamId: string, name: string, roles?: string[] }): Promise<Models.Team<Preferences>>;\n /**\n * Create a new team. The user who creates the team will automatically be assigned as the owner of the team. Only the users with the owner role can invite new members, add new owners and delete or update the team.\n *\n * @param {string} teamId - Team ID. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can't start with a special char. Max length is 36 chars.\n * @param {string} name - Team name. Max length: 128 chars.\n * @param {string[]} roles - Array of strings. Use this param to set the roles in the team for the user who created it. The default role is **owner**. A role can be any string. Learn more about [roles and permissions](https://appwrite.io/docs/permissions). Maximum of 100 roles are allowed, each 32 characters long.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Team<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n create<Preferences extends Models.Preferences = Models.DefaultPreferences>(teamId: string, name: string, roles?: string[]): Promise<Models.Team<Preferences>>;\n create<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { teamId: string, name: string, roles?: string[] } | string,\n ...rest: [(string)?, (string[])?] \n ): Promise<Models.Team<Preferences>> {\n let params: { teamId: string, name: string, roles?: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, name: string, roles?: string[] };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n name: rest[0] as string,\n roles: rest[1] as string[] \n };\n }\n\n const teamId = params.teamId;\n const name = params.name;\n const roles = params.roles;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof name === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"name\"');\n }\n\n const apiPath = '/teams';\n const payload: Payload = {};\n\n if (typeof teamId !== 'undefined') {\n payload['teamId'] = teamId;\n }\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n if (typeof roles !== 'undefined') {\n payload['roles'] = roles;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get a team by its ID. All team members have read access for this resource.\n *\n * @param {string} params.teamId - Team ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n get<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { teamId: string }): Promise<Models.Team<Preferences>>;\n /**\n * Get a team by its ID. All team members have read access for this resource.\n *\n * @param {string} teamId - Team ID.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Team<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n get<Preferences extends Models.Preferences = Models.DefaultPreferences>(teamId: string): Promise<Models.Team<Preferences>>;\n get<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { teamId: string } | string \n ): Promise<Models.Team<Preferences>> {\n let params: { teamId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string };\n } else {\n params = {\n teamId: paramsOrFirst as string \n };\n }\n\n const teamId = params.teamId;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n const apiPath = '/teams/{teamId}'.replace('{teamId}', teamId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Update the team's name by its unique ID.\n *\n * @param {string} params.teamId - Team ID.\n * @param {string} params.name - New team name. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateName<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { teamId: string, name: string }): Promise<Models.Team<Preferences>>;\n /**\n * Update the team's name by its unique ID.\n *\n * @param {string} teamId - Team ID.\n * @param {string} name - New team name. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Team<Preferences>>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateName<Preferences extends Models.Preferences = Models.DefaultPreferences>(teamId: string, name: string): Promise<Models.Team<Preferences>>;\n updateName<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { teamId: string, name: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Team<Preferences>> {\n let params: { teamId: string, name: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, name: string };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n name: rest[0] as string \n };\n }\n\n const teamId = params.teamId;\n const name = params.name;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof name === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"name\"');\n }\n\n const apiPath = '/teams/{teamId}'.replace('{teamId}', teamId);\n const payload: Payload = {};\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Delete a team using its ID. Only team members with the owner role can delete the team.\n *\n * @param {string} params.teamId - Team ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n delete(params: { teamId: string }): Promise<{}>;\n /**\n * Delete a team using its ID. Only team members with the owner role can delete the team.\n *\n * @param {string} teamId - Team ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n delete(teamId: string): Promise<{}>;\n delete(\n paramsOrFirst: { teamId: string } | string \n ): Promise<{}> {\n let params: { teamId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string };\n } else {\n params = {\n teamId: paramsOrFirst as string \n };\n }\n\n const teamId = params.teamId;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n const apiPath = '/teams/{teamId}'.replace('{teamId}', teamId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to list a team's members using the team's ID. All team members have read access to this endpoint. Hide sensitive attributes from the response by toggling membership privacy in the Console.\n *\n * @param {string} params.teamId - Team ID.\n * @param {string[]} params.queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: userId, teamId, invited, joined, confirm, roles\n * @param {string} params.search - Search term to filter your list results. Max length: 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n listMemberships(params: { teamId: string, queries?: string[], search?: string }): Promise<Models.MembershipList>;\n /**\n * Use this endpoint to list a team's members using the team's ID. All team members have read access to this endpoint. Hide sensitive attributes from the response by toggling membership privacy in the Console.\n *\n * @param {string} teamId - Team ID.\n * @param {string[]} queries - Array of query strings generated using the Query class provided by the SDK. [Learn more about queries](https://appwrite.io/docs/queries). Maximum of 100 queries are allowed, each 4096 characters long. You may filter on the following attributes: userId, teamId, invited, joined, confirm, roles\n * @param {string} search - Search term to filter your list results. Max length: 256 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.MembershipList>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n listMemberships(teamId: string, queries?: string[], search?: string): Promise<Models.MembershipList>;\n listMemberships(\n paramsOrFirst: { teamId: string, queries?: string[], search?: string } | string,\n ...rest: [(string[])?, (string)?] \n ): Promise<Models.MembershipList> {\n let params: { teamId: string, queries?: string[], search?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, queries?: string[], search?: string };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n queries: rest[0] as string[],\n search: rest[1] as string \n };\n }\n\n const teamId = params.teamId;\n const queries = params.queries;\n const search = params.search;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n const apiPath = '/teams/{teamId}/memberships'.replace('{teamId}', teamId);\n const payload: Payload = {};\n\n if (typeof queries !== 'undefined') {\n payload['queries'] = queries;\n }\n\n if (typeof search !== 'undefined') {\n payload['search'] = search;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Invite a new member to join your team. Provide an ID for existing users, or invite unregistered users using an email or phone number. If initiated from a Client SDK, Appwrite will send an email or sms with a link to join the team to the invited user, and an account will be created for them if one doesn't exist. If initiated from a Server SDK, the new member will be added automatically to the team.\n * \n * You only need to provide one of a user ID, email, or phone number. Appwrite will prioritize accepting the user ID > email > phone number if you provide more than one of these parameters.\n * \n * Use the `url` parameter to redirect the user from the invitation email to your app. After the user is redirected, use the [Update Team Membership Status](https://appwrite.io/docs/references/cloud/client-web/teams#updateMembershipStatus) endpoint to allow the user to accept the invitation to the team. \n * \n * Please note that to avoid a [Redirect Attack](https://github.com/OWASP/CheatSheetSeries/blob/master/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.md) Appwrite will accept the only redirect URLs under the domains you have added as a platform on the Appwrite Console.\n * \n *\n * @param {string} params.teamId - Team ID.\n * @param {string[]} params.roles - Array of strings. Use this param to set the user roles in the team. A role can be any string. Learn more about [roles and permissions](https://appwrite.io/docs/permissions). Maximum of 100 roles are allowed, each 32 characters long.\n * @param {string} params.email - Email of the new team member.\n * @param {string} params.userId - ID of the user to be added to a team.\n * @param {string} params.phone - Phone number. Format this number with a leading '+' and a country code, e.g., +16175551212.\n * @param {string} params.url - URL to redirect the user back to your app from the invitation email. This parameter is not required when an API key is supplied. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string} params.name - Name of the new team member. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n createMembership(params: { teamId: string, roles: string[], email?: string, userId?: string, phone?: string, url?: string, name?: string }): Promise<Models.Membership>;\n /**\n * Invite a new member to join your team. Provide an ID for existing users, or invite unregistered users using an email or phone number. If initiated from a Client SDK, Appwrite will send an email or sms with a link to join the team to the invited user, and an account will be created for them if one doesn't exist. If initiated from a Server SDK, the new member will be added automatically to the team.\n * \n * You only need to provide one of a user ID, email, or phone number. Appwrite will prioritize accepting the user ID > email > phone number if you provide more than one of these parameters.\n * \n * Use the `url` parameter to redirect the user from the invitation email to your app. After the user is redirected, use the [Update Team Membership Status](https://appwrite.io/docs/references/cloud/client-web/teams#updateMembershipStatus) endpoint to allow the user to accept the invitation to the team. \n * \n * Please note that to avoid a [Redirect Attack](https://github.com/OWASP/CheatSheetSeries/blob/master/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.md) Appwrite will accept the only redirect URLs under the domains you have added as a platform on the Appwrite Console.\n * \n *\n * @param {string} teamId - Team ID.\n * @param {string[]} roles - Array of strings. Use this param to set the user roles in the team. A role can be any string. Learn more about [roles and permissions](https://appwrite.io/docs/permissions). Maximum of 100 roles are allowed, each 32 characters long.\n * @param {string} email - Email of the new team member.\n * @param {string} userId - ID of the user to be added to a team.\n * @param {string} phone - Phone number. Format this number with a leading '+' and a country code, e.g., +16175551212.\n * @param {string} url - URL to redirect the user back to your app from the invitation email. This parameter is not required when an API key is supplied. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.\n * @param {string} name - Name of the new team member. Max length: 128 chars.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Membership>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n createMembership(teamId: string, roles: string[], email?: string, userId?: string, phone?: string, url?: string, name?: string): Promise<Models.Membership>;\n createMembership(\n paramsOrFirst: { teamId: string, roles: string[], email?: string, userId?: string, phone?: string, url?: string, name?: string } | string,\n ...rest: [(string[])?, (string)?, (string)?, (string)?, (string)?, (string)?] \n ): Promise<Models.Membership> {\n let params: { teamId: string, roles: string[], email?: string, userId?: string, phone?: string, url?: string, name?: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, roles: string[], email?: string, userId?: string, phone?: string, url?: string, name?: string };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n roles: rest[0] as string[],\n email: rest[1] as string,\n userId: rest[2] as string,\n phone: rest[3] as string,\n url: rest[4] as string,\n name: rest[5] as string \n };\n }\n\n const teamId = params.teamId;\n const roles = params.roles;\n const email = params.email;\n const userId = params.userId;\n const phone = params.phone;\n const url = params.url;\n const name = params.name;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof roles === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"roles\"');\n }\n\n const apiPath = '/teams/{teamId}/memberships'.replace('{teamId}', teamId);\n const payload: Payload = {};\n\n if (typeof email !== 'undefined') {\n payload['email'] = email;\n }\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof phone !== 'undefined') {\n payload['phone'] = phone;\n }\n\n if (typeof roles !== 'undefined') {\n payload['roles'] = roles;\n }\n\n if (typeof url !== 'undefined') {\n payload['url'] = url;\n }\n\n if (typeof name !== 'undefined') {\n payload['name'] = name;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('post', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get a team member by the membership unique id. All team members have read access for this resource. Hide sensitive attributes from the response by toggling membership privacy in the Console.\n *\n * @param {string} params.teamId - Team ID.\n * @param {string} params.membershipId - Membership ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getMembership(params: { teamId: string, membershipId: string }): Promise<Models.Membership>;\n /**\n * Get a team member by the membership unique id. All team members have read access for this resource. Hide sensitive attributes from the response by toggling membership privacy in the Console.\n *\n * @param {string} teamId - Team ID.\n * @param {string} membershipId - Membership ID.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Membership>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getMembership(teamId: string, membershipId: string): Promise<Models.Membership>;\n getMembership(\n paramsOrFirst: { teamId: string, membershipId: string } | string,\n ...rest: [(string)?] \n ): Promise<Models.Membership> {\n let params: { teamId: string, membershipId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, membershipId: string };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n membershipId: rest[0] as string \n };\n }\n\n const teamId = params.teamId;\n const membershipId = params.membershipId;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof membershipId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"membershipId\"');\n }\n\n const apiPath = '/teams/{teamId}/memberships/{membershipId}'.replace('{teamId}', teamId).replace('{membershipId}', membershipId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Modify the roles of a team member. Only team members with the owner role have access to this endpoint. Learn more about [roles and permissions](https://appwrite.io/docs/permissions).\n * \n *\n * @param {string} params.teamId - Team ID.\n * @param {string} params.membershipId - Membership ID.\n * @param {string[]} params.roles - An array of strings. Use this param to set the user's roles in the team. A role can be any string. Learn more about [roles and permissions](https://appwrite.io/docs/permissions). Maximum of 100 roles are allowed, each 32 characters long.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateMembership(params: { teamId: string, membershipId: string, roles: string[] }): Promise<Models.Membership>;\n /**\n * Modify the roles of a team member. Only team members with the owner role have access to this endpoint. Learn more about [roles and permissions](https://appwrite.io/docs/permissions).\n * \n *\n * @param {string} teamId - Team ID.\n * @param {string} membershipId - Membership ID.\n * @param {string[]} roles - An array of strings. Use this param to set the user's roles in the team. A role can be any string. Learn more about [roles and permissions](https://appwrite.io/docs/permissions). Maximum of 100 roles are allowed, each 32 characters long.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Membership>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMembership(teamId: string, membershipId: string, roles: string[]): Promise<Models.Membership>;\n updateMembership(\n paramsOrFirst: { teamId: string, membershipId: string, roles: string[] } | string,\n ...rest: [(string)?, (string[])?] \n ): Promise<Models.Membership> {\n let params: { teamId: string, membershipId: string, roles: string[] };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, membershipId: string, roles: string[] };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n membershipId: rest[0] as string,\n roles: rest[1] as string[] \n };\n }\n\n const teamId = params.teamId;\n const membershipId = params.membershipId;\n const roles = params.roles;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof membershipId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"membershipId\"');\n }\n\n if (typeof roles === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"roles\"');\n }\n\n const apiPath = '/teams/{teamId}/memberships/{membershipId}'.replace('{teamId}', teamId).replace('{membershipId}', membershipId);\n const payload: Payload = {};\n\n if (typeof roles !== 'undefined') {\n payload['roles'] = roles;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * This endpoint allows a user to leave a team or for a team owner to delete the membership of any other team member. You can also use this endpoint to delete a user membership even if it is not accepted.\n *\n * @param {string} params.teamId - Team ID.\n * @param {string} params.membershipId - Membership ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n deleteMembership(params: { teamId: string, membershipId: string }): Promise<{}>;\n /**\n * This endpoint allows a user to leave a team or for a team owner to delete the membership of any other team member. You can also use this endpoint to delete a user membership even if it is not accepted.\n *\n * @param {string} teamId - Team ID.\n * @param {string} membershipId - Membership ID.\n * @throws {AppwriteException}\n * @returns {Promise<{}>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n deleteMembership(teamId: string, membershipId: string): Promise<{}>;\n deleteMembership(\n paramsOrFirst: { teamId: string, membershipId: string } | string,\n ...rest: [(string)?] \n ): Promise<{}> {\n let params: { teamId: string, membershipId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, membershipId: string };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n membershipId: rest[0] as string \n };\n }\n\n const teamId = params.teamId;\n const membershipId = params.membershipId;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof membershipId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"membershipId\"');\n }\n\n const apiPath = '/teams/{teamId}/memberships/{membershipId}'.replace('{teamId}', teamId).replace('{membershipId}', membershipId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('delete', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Use this endpoint to allow a user to accept an invitation to join a team after being redirected back to your app from the invitation email received by the user.\n * \n * If the request is successful, a session for the user is automatically created.\n * \n *\n * @param {string} params.teamId - Team ID.\n * @param {string} params.membershipId - Membership ID.\n * @param {string} params.userId - User ID.\n * @param {string} params.secret - Secret key.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updateMembershipStatus(params: { teamId: string, membershipId: string, userId: string, secret: string }): Promise<Models.Membership>;\n /**\n * Use this endpoint to allow a user to accept an invitation to join a team after being redirected back to your app from the invitation email received by the user.\n * \n * If the request is successful, a session for the user is automatically created.\n * \n *\n * @param {string} teamId - Team ID.\n * @param {string} membershipId - Membership ID.\n * @param {string} userId - User ID.\n * @param {string} secret - Secret key.\n * @throws {AppwriteException}\n * @returns {Promise<Models.Membership>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updateMembershipStatus(teamId: string, membershipId: string, userId: string, secret: string): Promise<Models.Membership>;\n updateMembershipStatus(\n paramsOrFirst: { teamId: string, membershipId: string, userId: string, secret: string } | string,\n ...rest: [(string)?, (string)?, (string)?] \n ): Promise<Models.Membership> {\n let params: { teamId: string, membershipId: string, userId: string, secret: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, membershipId: string, userId: string, secret: string };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n membershipId: rest[0] as string,\n userId: rest[1] as string,\n secret: rest[2] as string \n };\n }\n\n const teamId = params.teamId;\n const membershipId = params.membershipId;\n const userId = params.userId;\n const secret = params.secret;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof membershipId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"membershipId\"');\n }\n\n if (typeof userId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"userId\"');\n }\n\n if (typeof secret === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"secret\"');\n }\n\n const apiPath = '/teams/{teamId}/memberships/{membershipId}/status'.replace('{teamId}', teamId).replace('{membershipId}', membershipId);\n const payload: Payload = {};\n\n if (typeof userId !== 'undefined') {\n payload['userId'] = userId;\n }\n\n if (typeof secret !== 'undefined') {\n payload['secret'] = secret;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('patch', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n\n /**\n * Get the team's shared preferences by its unique ID. If a preference doesn't need to be shared by all team members, prefer storing them in [user preferences](https://appwrite.io/docs/references/cloud/client-web/account#getPrefs).\n *\n * @param {string} params.teamId - Team ID.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n getPrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { teamId: string }): Promise<Preferences>;\n /**\n * Get the team's shared preferences by its unique ID. If a preference doesn't need to be shared by all team members, prefer storing them in [user preferences](https://appwrite.io/docs/references/cloud/client-web/account#getPrefs).\n *\n * @param {string} teamId - Team ID.\n * @throws {AppwriteException}\n * @returns {Promise<Preferences>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n getPrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(teamId: string): Promise<Preferences>;\n getPrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { teamId: string } | string \n ): Promise<Preferences> {\n let params: { teamId: string };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string };\n } else {\n params = {\n teamId: paramsOrFirst as string \n };\n }\n\n const teamId = params.teamId;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n const apiPath = '/teams/{teamId}/prefs'.replace('{teamId}', teamId);\n const payload: Payload = {};\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('get', uri, {\n }, payload);\n }\n\n /**\n * Update the team's preferences by its unique ID. The object you pass is stored as is and replaces any previous value. The maximum allowed prefs size is 64kB and throws an error if exceeded.\n *\n * @param {string} params.teamId - Team ID.\n * @param {object} params.prefs - Prefs key-value JSON object.\n * @throws {AppwriteException}\n * @returns {Promise}\n */\n updatePrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(params: { teamId: string, prefs: object }): Promise<Preferences>;\n /**\n * Update the team's preferences by its unique ID. The object you pass is stored as is and replaces any previous value. The maximum allowed prefs size is 64kB and throws an error if exceeded.\n *\n * @param {string} teamId - Team ID.\n * @param {object} prefs - Prefs key-value JSON object.\n * @throws {AppwriteException}\n * @returns {Promise<Preferences>}\n * @deprecated Use the object parameter style method for a better developer experience.\n */\n updatePrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(teamId: string, prefs: object): Promise<Preferences>;\n updatePrefs<Preferences extends Models.Preferences = Models.DefaultPreferences>(\n paramsOrFirst: { teamId: string, prefs: object } | string,\n ...rest: [(object)?] \n ): Promise<Preferences> {\n let params: { teamId: string, prefs: object };\n\n if ((paramsOrFirst && typeof paramsOrFirst === 'object' && !Array.isArray(paramsOrFirst))) {\n params = (paramsOrFirst || {}) as { teamId: string, prefs: object };\n } else {\n params = {\n teamId: paramsOrFirst as string,\n prefs: rest[0] as object \n };\n }\n\n const teamId = params.teamId;\n const prefs = params.prefs;\n\n if (typeof teamId === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"teamId\"');\n }\n\n if (typeof prefs === 'undefined') {\n throw new AppwriteException('Missing required parameter: \"prefs\"');\n }\n\n const apiPath = '/teams/{teamId}/prefs'.replace('{teamId}', teamId);\n const payload: Payload = {};\n\n if (typeof prefs !== 'undefined') {\n payload['prefs'] = prefs;\n }\n\n const uri = new URL(this.client.config.endpoint + apiPath);\n return this.client.call('put', uri, {\n 'content-type': 'application/json',\n }, payload);\n }\n};\n","type QueryTypesSingle = string | number | boolean;\nexport type QueryTypesList = string[] | number[] | boolean[] | Query[] | any[];\nexport type QueryTypes = QueryTypesSingle | QueryTypesList;\ntype AttributesTypes = string | string[];\n\nexport class Query {\n method: string;\n attribute: AttributesTypes | undefined;\n values: QueryTypesList | undefined;\n\n constructor(\n method: string,\n attribute?: AttributesTypes,\n values?: QueryTypes\n ) {\n this.method = method;\n this.attribute = attribute;\n\n if (values !== undefined) {\n if (Array.isArray(values)) {\n this.values = values;\n } else {\n this.values = [values] as QueryTypesList;\n }\n }\n }\n\n toString(): string {\n return JSON.stringify({\n method: this.method,\n attribute: this.attribute,\n values: this.values,\n });\n }\n\n static equal = (attribute: string, value: QueryTypes): string =>\n new Query(\"equal\", attribute, value).toString();\n\n static notEqual = (attribute: string, value: QueryTypes): string =>\n new Query(\"notEqual\", attribute, value).toString();\n\n static lessThan = (attribute: string, value: QueryTypes): string =>\n new Query(\"lessThan\", attribute, value).toString();\n\n static lessThanEqual = (attribute: string, value: QueryTypes): string =>\n new Query(\"lessThanEqual\", attribute, value).toString();\n\n static greaterThan = (attribute: string, value: QueryTypes): string =>\n new Query(\"greaterThan\", attribute, value).toString();\n\n static greaterThanEqual = (attribute: string, value: QueryTypes): string =>\n new Query(\"greaterThanEqual\", attribute, value).toString();\n\n static isNull = (attribute: string): string =>\n new Query(\"isNull\", attribute).toString();\n\n static isNotNull = (attribute: string): string =>\n new Query(\"isNotNull\", attribute).toString();\n\n static between = (attribute: string, start: string | number, end: string | number) =>\n new Query(\"between\", attribute, [start, end] as QueryTypesList).toString();\n\n static startsWith = (attribute: string, value: string): string =>\n new Query(\"startsWith\", attribute, value).toString();\n\n static endsWith = (attribute: string, value: string): string =>\n new Query(\"endsWith\", attribute, value).toString();\n\n static select = (attributes: string[]): string =>\n new Query(\"select\", undefined, attributes).toString();\n\n static search = (attribute: string, value: string): string =>\n new Query(\"search\", attribute, value).toString();\n\n static orderDesc = (attribute: string): string =>\n new Query(\"orderDesc\", attribute).toString();\n\n static orderAsc = (attribute: string): string =>\n new Query(\"orderAsc\", attribute).toString();\n\n static orderRandom = (): string =>\n new Query(\"orderRandom\").toString();\n\n static cursorAfter = (documentId: string): string =>\n new Query(\"cursorAfter\", undefined, documentId).toString();\n\n static cursorBefore = (documentId: string): string =>\n new Query(\"cursorBefore\", undefined, documentId).toString();\n\n static limit = (limit: number): string =>\n new Query(\"limit\", undefined, limit).toString();\n\n static offset = (offset: number): string =>\n new Query(\"offset\", undefined, offset).toString();\n\n /**\n * Filter resources where attribute contains the specified value.\n *\n * @param {string} attribute\n * @param {string | string[]} value\n * @returns {string}\n */\n static contains = (attribute: string, value: string | any[]): string =>\n new Query(\"contains\", attribute, value).toString();\n\n /**\n * Filter resources where attribute does not contain the specified value.\n *\n * @param {string} attribute\n * @param {string | string[]} value\n * @returns {string}\n */\n static notContains = (attribute: string, value: string | any[]): string =>\n new Query(\"notContains\", attribute, value).toString();\n\n /**\n * Filter resources by searching attribute for value (inverse of search).\n * A fulltext index on attribute is required for this query to work.\n *\n * @param {string} attribute\n * @param {string} value\n * @returns {string}\n */\n static notSearch = (attribute: string, value: string): string =>\n new Query(\"notSearch\", attribute, value).toString();\n\n /**\n * Filter resources where attribute is not between start and end (exclusive).\n *\n * @param {string} attribute\n * @param {string | number} start\n * @param {string | number} end\n * @returns {string}\n */\n static notBetween = (attribute: string, start: string | number, end: string | number): string =>\n new Query(\"notBetween\", attribute, [start, end] as QueryTypesList).toString();\n\n /**\n * Filter resources where attribute does not start with value.\n *\n * @param {string} attribute\n * @param {string} value\n * @returns {string}\n */\n static notStartsWith = (attribute: string, value: string): string =>\n new Query(\"notStartsWith\", attribute, value).toString();\n\n /**\n * Filter resources where attribute does not end with value.\n *\n * @param {string} attribute\n * @param {string} value\n * @returns {string}\n */\n static notEndsWith = (attribute: string, value: string): string =>\n new Query(\"notEndsWith\", attribute, value).toString();\n\n /**\n * Filter resources where document was created before date.\n *\n * @param {string} value\n * @returns {string}\n */\n static createdBefore = (value: string): string =>\n new Query(\"createdBefore\", undefined, value).toString();\n\n /**\n * Filter resources where document was created after date.\n *\n * @param {string} value\n * @returns {string}\n */\n static createdAfter = (value: string): string =>\n new Query(\"createdAfter\", undefined, value).toString();\n\n /**\n * Filter resources where document was created between dates.\n *\n * @param {string} start\n * @param {string} end\n * @returns {string}\n */\n static createdBetween = (start: string, end: string): string =>\n new Query(\"createdBetween\", undefined, [start, end] as QueryTypesList).toString();\n\n /**\n * Filter resources where document was updated before date.\n *\n * @param {string} value\n * @returns {string}\n */\n static updatedBefore = (value: string): string =>\n new Query(\"updatedBefore\", undefined, value).toString();\n\n /**\n * Filter resources where document was updated after date.\n *\n * @param {string} value\n * @returns {string}\n */\n static updatedAfter = (value: string): string =>\n new Query(\"updatedAfter\", undefined, value).toString();\n\n /**\n * Filter resources where document was updated between dates.\n *\n * @param {string} start\n * @param {string} end\n * @returns {string}\n */\n static updatedBetween = (start: string, end: string): string =>\n new Query(\"updatedBetween\", undefined, [start, end] as QueryTypesList).toString();\n\n static or = (queries: string[]) =>\n new Query(\"or\", undefined, queries.map((query) => JSON.parse(query))).toString();\n\n static and = (queries: string[]) =>\n new Query(\"and\", undefined, queries.map((query) => JSON.parse(query))).toString();\n\n /**\n * Filter resources where attribute is at a specific distance from the given coordinates.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @param {number} distance\n * @param {boolean} meters\n * @returns {string}\n */\n static distanceEqual = (attribute: string, values: any[], distance: number, meters: boolean = true): string =>\n new Query(\"distanceEqual\", attribute, [[values, distance, meters]] as QueryTypesList).toString();\n\n /**\n * Filter resources where attribute is not at a specific distance from the given coordinates.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @param {number} distance\n * @param {boolean} meters\n * @returns {string}\n */\n static distanceNotEqual = (attribute: string, values: any[], distance: number, meters: boolean = true): string =>\n new Query(\"distanceNotEqual\", attribute, [[values, distance, meters]] as QueryTypesList).toString();\n\n /**\n * Filter resources where attribute is at a distance greater than the specified value from the given coordinates.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @param {number} distance\n * @param {boolean} meters\n * @returns {string}\n */\n static distanceGreaterThan = (attribute: string, values: any[], distance: number, meters: boolean = true): string =>\n new Query(\"distanceGreaterThan\", attribute, [[values, distance, meters]] as QueryTypesList).toString();\n\n /**\n * Filter resources where attribute is at a distance less than the specified value from the given coordinates.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @param {number} distance\n * @param {boolean} meters\n * @returns {string}\n */\n static distanceLessThan = (attribute: string, values: any[], distance: number, meters: boolean = true): string =>\n new Query(\"distanceLessThan\", attribute, [[values, distance, meters]] as QueryTypesList).toString();\n\n /**\n * Filter resources where attribute intersects with the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static intersects = (attribute: string, values: any[]): string =>\n new Query(\"intersects\", attribute, [values]).toString();\n\n /**\n * Filter resources where attribute does not intersect with the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static notIntersects = (attribute: string, values: any[]): string =>\n new Query(\"notIntersects\", attribute, [values]).toString();\n\n /**\n * Filter resources where attribute crosses the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static crosses = (attribute: string, values: any[]): string =>\n new Query(\"crosses\", attribute, [values]).toString();\n\n /**\n * Filter resources where attribute does not cross the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static notCrosses = (attribute: string, values: any[]): string =>\n new Query(\"notCrosses\", attribute, [values]).toString();\n\n /**\n * Filter resources where attribute overlaps with the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static overlaps = (attribute: string, values: any[]): string =>\n new Query(\"overlaps\", attribute, [values]).toString();\n\n /**\n * Filter resources where attribute does not overlap with the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static notOverlaps = (attribute: string, values: any[]): string =>\n new Query(\"notOverlaps\", attribute, [values]).toString();\n\n /**\n * Filter resources where attribute touches the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static touches = (attribute: string, values: any[]): string =>\n new Query(\"touches\", attribute, [values]).toString();\n\n /**\n * Filter resources where attribute does not touch the given geometry.\n *\n * @param {string} attribute\n * @param {any[]} values\n * @returns {string}\n */\n static notTouches = (attribute: string, values: any[]): string =>\n new Query(\"notTouches\", attribute, [values]).toString();\n}\n","export class Permission {\n\n static read = (role: string): string => {\n return `read(\"${role}\")`\n }\n\n static write = (role: string): string => {\n return `write(\"${role}\")`\n }\n\n static create = (role: string): string => {\n return `create(\"${role}\")`\n }\n\n static update = (role: string): string => {\n return `update(\"${role}\")`\n }\n\n static delete = (role: string): string => {\n return `delete(\"${role}\")`\n }\n}\n","/**\n * Helper class to generate role strings for `Permission`.\n */\nexport class Role {\n\n /**\n * Grants access to anyone.\n * \n * This includes authenticated and unauthenticated users.\n * \n * @returns {string}\n */\n public static any(): string {\n return 'any'\n }\n\n /**\n * Grants access to a specific user by user ID.\n * \n * You can optionally pass verified or unverified for\n * `status` to target specific types of users.\n *\n * @param {string} id \n * @param {string} status \n * @returns {string}\n */\n public static user(id: string, status: string = ''): string {\n if (status === '') {\n return `user:${id}`\n }\n return `user:${id}/${status}`\n }\n\n /**\n * Grants access to any authenticated or anonymous user.\n * \n * You can optionally pass verified or unverified for\n * `status` to target specific types of users.\n * \n * @param {string} status \n * @returns {string}\n */\n public static users(status: string = ''): string {\n if (status === '') {\n return 'users'\n }\n return `users/${status}`\n }\n\n /**\n * Grants access to any guest user without a session.\n * \n * Authenticated users don't have access to this role.\n * \n * @returns {string}\n */\n public static guests(): string {\n return 'guests'\n }\n\n /**\n * Grants access to a team by team ID.\n * \n * You can optionally pass a role for `role` to target\n * team members with the specified role.\n * \n * @param {string} id \n * @param {string} role \n * @returns {string}\n */\n public static team(id: string, role: string = ''): string {\n if (role === '') {\n return `team:${id}`\n }\n return `team:${id}/${role}`\n }\n\n /**\n * Grants access to a specific member of a team.\n * \n * When the member is removed from the team, they will\n * no longer have access.\n * \n * @param {string} id \n * @returns {string}\n */\n public static member(id: string): string {\n return `member:${id}`\n }\n\n /**\n * Grants access to a user with the specified label.\n * \n * @param {string} name \n * @returns {string}\n */\n public static label(name: string): string {\n return `label:${name}`\n }\n}","export class ID {\n // Generate an hex ID based on timestamp\n // Recreated from https://www.php.net/manual/en/function.uniqid.php\n static #hexTimestamp(): string {\n const now = new Date();\n const sec = Math.floor(now.getTime() / 1000);\n const msec = now.getMilliseconds();\n\n // Convert to hexadecimal\n const hexTimestamp = sec.toString(16) + msec.toString(16).padStart(5, '0');\n return hexTimestamp;\n }\n\n public static custom(id: string): string {\n return id\n }\n\n public static unique(padding: number = 7): string {\n // Generate a unique ID with padding to have a longer ID\n const baseId = ID.#hexTimestamp();\n let randomPadding = '';\n for (let i = 0; i < padding; i++) {\n const randomHexDigit = Math.floor(Math.random() * 16).toString(16);\n randomPadding += randomHexDigit;\n }\n return baseId + randomPadding;\n }\n}\n","export enum AuthenticatorType {\n Totp = 'totp',\n}","export enum AuthenticationFactor {\n Email = 'email',\n Phone = 'phone',\n Totp = 'totp',\n Recoverycode = 'recoverycode',\n}","export enum OAuthProvider {\n Amazon = 'amazon',\n Apple = 'apple',\n Auth0 = 'auth0',\n Authentik = 'authentik',\n Autodesk = 'autodesk',\n Bitbucket = 'bitbucket',\n Bitly = 'bitly',\n Box = 'box',\n Dailymotion = 'dailymotion',\n Discord = 'discord',\n Disqus = 'disqus',\n Dropbox = 'dropbox',\n Etsy = 'etsy',\n Facebook = 'facebook',\n Figma = 'figma',\n Github = 'github',\n Gitlab = 'gitlab',\n Google = 'google',\n Linkedin = 'linkedin',\n Microsoft = 'microsoft',\n Notion = 'notion',\n Oidc = 'oidc',\n Okta = 'okta',\n Paypal = 'paypal',\n PaypalSandbox = 'paypalSandbox',\n Podio = 'podio',\n Salesforce = 'salesforce',\n Slack = 'slack',\n Spotify = 'spotify',\n Stripe = 'stripe',\n Tradeshift = 'tradeshift',\n TradeshiftBox = 'tradeshiftBox',\n Twitch = 'twitch',\n Wordpress = 'wordpress',\n Yahoo = 'yahoo',\n Yammer = 'yammer',\n Yandex = 'yandex',\n Zoho = 'zoho',\n Zoom = 'zoom',\n Mock = 'mock',\n}","export enum Browser {\n AvantBrowser = 'aa',\n AndroidWebViewBeta = 'an',\n GoogleChrome = 'ch',\n GoogleChromeIOS = 'ci',\n GoogleChromeMobile = 'cm',\n Chromium = 'cr',\n MozillaFirefox = 'ff',\n Safari = 'sf',\n MobileSafari = 'mf',\n MicrosoftEdge = 'ps',\n MicrosoftEdgeIOS = 'oi',\n OperaMini = 'om',\n Opera = 'op',\n OperaNext = 'on',\n}","export enum CreditCard {\n AmericanExpress = 'amex',\n Argencard = 'argencard',\n Cabal = 'cabal',\n Cencosud = 'cencosud',\n DinersClub = 'diners',\n Discover = 'discover',\n Elo = 'elo',\n Hipercard = 'hipercard',\n JCB = 'jcb',\n Mastercard = 'mastercard',\n Naranja = 'naranja',\n TarjetaShopping = 'targeta-shopping',\n UnionPay = 'unionpay',\n Visa = 'visa',\n MIR = 'mir',\n Maestro = 'maestro',\n Rupay = 'rupay',\n}","export enum Flag {\n Afghanistan = 'af',\n Angola = 'ao',\n Albania = 'al',\n Andorra = 'ad',\n UnitedArabEmirates = 'ae',\n Argentina = 'ar',\n Armenia = 'am',\n AntiguaAndBarbuda = 'ag',\n Australia = 'au',\n Austria = 'at',\n Azerbaijan = 'az',\n Burundi = 'bi',\n Belgium = 'be',\n Benin = 'bj',\n BurkinaFaso = 'bf',\n Bangladesh = 'bd',\n Bulgaria = 'bg',\n Bahrain = 'bh',\n Bahamas = 'bs',\n BosniaAndHerzegovina = 'ba',\n Belarus = 'by',\n Belize = 'bz',\n Bolivia = 'bo',\n Brazil = 'br',\n Barbados = 'bb',\n BruneiDarussalam = 'bn',\n Bhutan = 'bt',\n Botswana = 'bw',\n CentralAfricanRepublic = 'cf',\n Canada = 'ca',\n Switzerland = 'ch',\n Chile = 'cl',\n China = 'cn',\n CoteDIvoire = 'ci',\n Cameroon = 'cm',\n DemocraticRepublicOfTheCongo = 'cd',\n RepublicOfTheCongo = 'cg',\n Colombia = 'co',\n Comoros = 'km',\n CapeVerde = 'cv',\n CostaRica = 'cr',\n Cuba = 'cu',\n Cyprus = 'cy',\n CzechRepublic = 'cz',\n Germany = 'de',\n Djibouti = 'dj',\n Dominica = 'dm',\n Denmark = 'dk',\n DominicanRepublic = 'do',\n Algeria = 'dz',\n Ecuador = 'ec',\n Egypt = 'eg',\n Eritrea = 'er',\n Spain = 'es',\n Estonia = 'ee',\n Ethiopia = 'et',\n Finland = 'fi',\n Fiji = 'fj',\n France = 'fr',\n MicronesiaFederatedStatesOf = 'fm',\n Gabon = 'ga',\n UnitedKingdom = 'gb',\n Georgia = 'ge',\n Ghana = 'gh',\n Guinea = 'gn',\n Gambia = 'gm',\n GuineaBissau = 'gw',\n EquatorialGuinea = 'gq',\n Greece = 'gr',\n Grenada = 'gd',\n Guatemala = 'gt',\n Guyana = 'gy',\n Honduras = 'hn',\n Croatia = 'hr',\n Haiti = 'ht',\n Hungary = 'hu',\n Indonesia = 'id',\n India = 'in',\n Ireland = 'ie',\n IranIslamicRepublicOf = 'ir',\n Iraq = 'iq',\n Iceland = 'is',\n Israel = 'il',\n Italy = 'it',\n Jamaica = 'jm',\n Jordan = 'jo',\n Japan = 'jp',\n Kazakhstan = 'kz',\n Kenya = 'ke',\n Kyrgyzstan = 'kg',\n Cambodia = 'kh',\n Kiribati = 'ki',\n SaintKittsAndNevis = 'kn',\n SouthKorea = 'kr',\n Kuwait = 'kw',\n LaoPeopleSDemocraticRepublic = 'la',\n Lebanon = 'lb',\n Liberia = 'lr',\n Libya = 'ly',\n SaintLucia = 'lc',\n Liechtenstein = 'li',\n SriLanka = 'lk',\n Lesotho = 'ls',\n Lithuania = 'lt',\n Luxembourg = 'lu',\n Latvia = 'lv',\n Morocco = 'ma',\n Monaco = 'mc',\n Moldova = 'md',\n Madagascar = 'mg',\n Maldives = 'mv',\n Mexico = 'mx',\n MarshallIslands = 'mh',\n NorthMacedonia = 'mk',\n Mali = 'ml',\n Malta = 'mt',\n Myanmar = 'mm',\n Montenegro = 'me',\n Mongolia = 'mn',\n Mozambique = 'mz',\n Mauritania = 'mr',\n Mauritius = 'mu',\n Malawi = 'mw',\n Malaysia = 'my',\n Namibia = 'na',\n Niger = 'ne',\n Nigeria = 'ng',\n Nicaragua = 'ni',\n Netherlands = 'nl',\n Norway = 'no',\n Nepal = 'np',\n Nauru = 'nr',\n NewZealand = 'nz',\n Oman = 'om',\n Pakistan = 'pk',\n Panama = 'pa',\n Peru = 'pe',\n Philippines = 'ph',\n Palau = 'pw',\n PapuaNewGuinea = 'pg',\n Poland = 'pl',\n FrenchPolynesia = 'pf',\n NorthKorea = 'kp',\n Portugal = 'pt',\n Paraguay = 'py',\n Qatar = 'qa',\n Romania = 'ro',\n Russia = 'ru',\n Rwanda = 'rw',\n SaudiArabia = 'sa',\n Sudan = 'sd',\n Senegal = 'sn',\n Singapore = 'sg',\n SolomonIslands = 'sb',\n SierraLeone = 'sl',\n ElSalvador = 'sv',\n SanMarino = 'sm',\n Somalia = 'so',\n Serbia = 'rs',\n SouthSudan = 'ss',\n SaoTomeAndPrincipe = 'st',\n Suriname = 'sr',\n Slovakia = 'sk',\n Slovenia = 'si',\n Sweden = 'se',\n Eswatini = 'sz',\n Seychelles = 'sc',\n Syria = 'sy',\n Chad = 'td',\n Togo = 'tg',\n Thailand = 'th',\n Tajikistan = 'tj',\n Turkmenistan = 'tm',\n TimorLeste = 'tl',\n Tonga = 'to',\n TrinidadAndTobago = 'tt',\n Tunisia = 'tn',\n Turkey = 'tr',\n Tuvalu = 'tv',\n Tanzania = 'tz',\n Uganda = 'ug',\n Ukraine = 'ua',\n Uruguay = 'uy',\n UnitedStates = 'us',\n Uzbekistan = 'uz',\n VaticanCity = 'va',\n SaintVincentAndTheGrenadines = 'vc',\n Venezuela = 've',\n Vietnam = 'vn',\n Vanuatu = 'vu',\n Samoa = 'ws',\n Yemen = 'ye',\n SouthAfrica = 'za',\n Zambia = 'zm',\n Zimbabwe = 'zw',\n}","export enum ExecutionMethod {\n GET = 'GET',\n POST = 'POST',\n PUT = 'PUT',\n PATCH = 'PATCH',\n DELETE = 'DELETE',\n OPTIONS = 'OPTIONS',\n HEAD = 'HEAD',\n}","export enum ImageGravity {\n Center = 'center',\n TopLeft = 'top-left',\n Top = 'top',\n TopRight = 'top-right',\n Left = 'left',\n Right = 'right',\n BottomLeft = 'bottom-left',\n Bottom = 'bottom',\n BottomRight = 'bottom-right',\n}","export enum ImageFormat {\n Jpg = 'jpg',\n Jpeg = 'jpeg',\n Png = 'png',\n Webp = 'webp',\n Heic = 'heic',\n Avif = 'avif',\n Gif = 'gif',\n}"],"names":[],"mappings":"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"}
|