{"version":3,"sources":["../src/polyfills/global.ts","../src/main/error.ts","../src/utils/utils.ts","../src/utils/validator.ts","../src/methods/user.ts","../src/utils/network.ts","../src/methods/param_restrictions.ts","../src/methods/database.ts","../src/methods/webrtc.ts","../src/methods/realtime.ts","../src/methods/request.ts","../src/methods/subscription.ts","../src/methods/admin.ts","../src/methods/notification.ts","../src/methods/vivian.ts","../src/main/skapi.ts","../src/Types.ts"],"names":["root","win","toBase64Url","input","binary","bytes","chunk","i","slice","NodeFileReader","blob","buffer","base64","mimeType","err","encoding","text","NodeXMLHttpRequest","method","url","name","value","body","fetchOptions","response","error","message","key","fs","path","filePath","dirPath","constraints","SkapiError","options","msg","BASE62_ALPHABET","BASE62","MAX_FORM_DATA_SIZE","USER_ATTRIBUTE_EXCLUDES","USER_ATTRIBUTE_CONVERTS","SERVICE_REGION_ALPHABET","SERVICE_REGION_KEYS","textEncoder","getGlobalBuffer","encodeUtf8","toUint8Array","BufferCtor","_MD5","str","x","a","b","c","d","lastA","lastB","lastC","lastD","n","s","j","y","l","q","t","numBlocks","blocks","MD5","toBase62","num","result","fromBase62","chars","prev","curr","generateRandom","length","characters","charactersLength","counter","isNodeRuntime","isBrowserRuntime","assertMaxFormDataSize","serialized","isDefaultTruthyInputValue","isDefaultFalsyInputValue","appendNamedElementValue","data","element","appendData","isBrowser","hasSubmitEvent","hasHTMLFormElement","extractFormData","form","callback","files","val","v","keys","k","numb","obj","handleFile","idx","file","handleInput","pair","json","inputs","selects","textarea","parseUserAttributes","attr","user","addr_main","decodeServiceId","service","decompressCompoundId","idSplit","region","owner","formatServiceId","serviceId","ownerId","regionIndex","regionChar","formattedServiceId","compressCompoundId","b62ToBigInt","ch","bigIntToB62","minLength","output","current","remainder","bigIntToBytes","bytesToBigInt","buf","uuidToBytes","uuid","hex","bytesToUuid","buf16","inputString","match","firstPart","secondPart","movedPrefix","movedFirstPart","movedMiddlePart","part1","uuidBytes","part2","token","tokenString","split","secondLength","compacted","movedMiddleLength","uuidValue","uuidRaw","UserId","id","param","uuid_regex","PhoneNumber","Birthdate","birthdate","date_regex","Password","password","Email","email","paramName","Url","hasWindow","baseUrl","check","cu","curr_loc","_url","u","Params","params","struct","required","ext","p","toCheck","cocochex","validator_default","cognitoUser","map_ticket_obj","mapper","new_obj","tkid","rand","timestampStr","consumeTicket","ticket_id","resp","request","getTickets","tickets","getConsumedTickets","registerTicket","unregisterTicket","getJwtToken","currentTime","idTokenExp","authentication","_out","refreshSession","session","res","rej","refreshErr","refreshedSession","getUserProfile","getSession","option","refreshToken","skipUserUpdateEventTrigger","respond","sessionAttribute","r","idToken","isExpired","createCognitoUser","un","raw","username","CognitoUser","is_openid","initUser","authenticationDetails","AuthenticationDetails","userAttributes","requiredAttributes","_","parsed","code","cognitoErrorParser","cognitoMessage","errCode","errMsg","attributes","original_code","err_msg","custom","err_code","err_msg_custom","getProfile","openIdLogin","item","oplog","logger","decodeBase64Utf8","getUserFromToken","accessToken","parts","decoded","loginWithToken","idTokenPayload","CognitoUserSession","CognitoIdToken","CognitoAccessToken","CognitoRefreshToken","up","symbols","descriptors","e","checkAdmin","logout","global","toReturn","to_be_erased","resendSignupConfirmation","recoverAccount","redirect","login","signup","paramRestrictions","logUser","newUser","signup_key","signup_ticket","attributeList","CognitoUserAttribute","customParams","disableAccount","resetPassword","new_password","verifyAttribute","attribute","verifyPhoneNumber","verifyEmail","forgotPassword","mappedCode","changePassword","updateProfile","collision","toRemove","parseValue","toSet","getUsers","searchForTypes","checker","lastVerifiedEmail","requestUsernameChange","requestQueue","request_counter","getRetryDelayMs","retryAfter","seconds","dateMs","toPercent","loaded","total","selectGateway","auth","type","endpoints","admin","record","gateways_admin_round_robin","gateways_record_round_robin","getEndpoint","dest","query","__pendingRequest","terminatePendingRequests","_etc","bypassAwaitConnection","__connection","endpoint","fetchMore","progress","requestFingerprint","hashedParams","sortObject","requestKey","requestKeyWithStartKey","load_startKey_keys","headers","configuredContentType","meta","opt","stringValue","separator","encoded","config","cb","Qpass","promise","_fetch","update_startKey_keys","hashedParams_cached","list_of_startKeys","last_startKey_key","xhr","retryDelayMs","status","cause","hashedParam","fetched","startKey_string","uploadFiles","fileList","record_id","getSignedParams","fetchProgress","progressCallback","base62Chars","completed","failed","bin_endpoints","signedParams","fields","cdn","pendPromise","formHandler","preventMultipleCalls","target","propertyKey","descriptor","fn","arg","storeResponseKey","formEl","actionDestination","fileBase64String","refreshPage","currentUrl","href","placeholders","inputElement","reader","handleResponse","handleError","executeMethod","resolved","pendingKey","getFormResponse","responseKey","stored","MAX_TABLE_NAME_LENGTH","MAX_TAG_LENGTH","MAX_INDEX_NAME_LENGTH","MAX_INDEX_STRING_VALUE_LENGTH","SENTINEL_CHAR","CONTROL_OR_SENTINEL_REGEX","BLOCKED_KEY_SEGMENT_DELIMITER_REGEX","validateStringByPolicy","fieldName","allowEmpty","maxLength","blockKeyDelimiters","disallowLeadingDollar","onlyAlphanumeric","validateTableName","validateTag","validateCustomIndexName","validateIndexStringValue","recordIdOrUniqueId","outputObj","accessGroup","__index_number_range","indexValue","indexRange","pendingPrivateAccessKeyRequest","normalizeRecord","_called_from","is_anonymous","access_group_set","access_group","split_ip","ip","base62timestamp","uploaded","rSplit","normalizeTypedString","binObj","_ref","parsedBin","splitPath","filename","pathKey","size","url_endpoint","getFile","dataType","exec","splitDec","calcNumb","deleteFiles","updatedRec","to_process","splitQuery","queryString","validatedBaseUrl","isValidEndpoint","splitUrl","splitHost","subdomain","target_key","needAuth","expires","currTime","user_access_group","getQuery","isDel","is_reference_fetch","rec_or_uniq","isAdmin","ref","ref_user_is_me","buildStruct","indexTypes","tp","getRecords","setupPostRecordConfig","is_reference_post","_config","qq","vv","arr","pc","hasEnabledSubscriptionOptions","bulkPostRecords","reference_posts","postData","mangled","recList","records","rec","postRecord","postConf","to_bin","extractedForm","bin_formData","f","uploadFileParams","getTables","convert","getIndexes","iSplit","getTags","tSplit","getUniqueId","deleteRecords","grantPrivateRecordAccess","recordAccess","removePrivateRecordAccess","listPrivateRecordAccess","list","requestPrivateRecordAccessKey","reference_id","privateKey","req","__peerConnection","__dataChannel","__caller_ringing","__receiver_ringing","__rtcEvents","__rtcCandidatesBuffer","__rtcSdpOfferBuffer","setBuffer","recipient","processBuffer","proceed","process","answerSdpOffer","offer","socket","sendAnswer","answer","receiveIceCandidate","candidate","closeRTC","cid","close_all","close","channel","track","createMediaStream","media","dummyStream","canvas","dummyVideoTrack","connectRTC","ice","configuration","protocol","dataChannel","handleDataChannel","peerConnectionHandler","sendOffer","resolve","respondRTC","sender","event","sdpoffer","sendIceCandidate","skipKey","skip","peer","handlers","state","handler","events","closed","__current_socket_room","__keepAliveInterval","closedByIntention","reconnectAttempts","prepareWebsocket","visibilitychange","closeRealtime","joinRealtime","connectRealtime","delay","reconnect","workerScript","rtc","postRealtime","notification","notificationStr","group","getRealtimeUsers","getRealtimeGroups","hasFormData","clientSecretRequest","hasSecret","checkClientSecretPlaceholder","lo","sendInquiry","secureRequest","formData","paramsStruct","mock","responseType","contentType","getFeed","recs","cannotBeSelfId","getSubscriptions","subscription","subSplit","subscribe","unsubscribe","user_id","blockSubscriber","unblockSubscriber","getNewsletterSubscription","sub","subt","active","subscribeNewsletter","unsubscribeNewsletter","param_send","getNewsletters","searchType","endpointTarget","mails","remap","defaults","m","remapped","blockAccount","unblockAccount","deleteAccount","inviteUser","createAccount","grantAccess","getInvitations","cancelInvitation","resendInvitation","subscribeNotification","unsubscribeNotification","vapidPublicKey","pushNotification","user_ids","title","payload","spellcast","getspell","dopamine","Skapi","__etc","schema","idSplitLen","autoLogin","cdn_domain","sreg","reject","restore","admin_endpoint","poolSetting","CognitoUserPool","uniqueids","connection","storeClassProperties","to_be_cached","conn","listener","ua","__decorateClass","Types_exports"],"mappings":"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","file":"skapi.mjs","sourcesContent":["// Platform-aware global polyfill\nconst root = typeof globalThis !== 'undefined' ? (globalThis as any) : undefined;\nconst win = root?.window;\n\nfunction toBase64Url(input) {\n    if (Buffer) {\n        return Buffer.from(input).toString('base64');\n    }\n\n    let binary = '';\n    const bytes = new Uint8Array(input);\n    const chunk = 0x8000;\n\n    for (let i = 0; i < bytes.length; i += chunk) {\n        const slice = bytes.subarray(i, i + chunk);\n        binary += String.fromCharCode.apply(null, Array.from(slice));\n    }\n\n    if (typeof btoa === 'function') {\n        return btoa(binary);\n    }\n\n    throw new Error('No base64 encoder available in this environment.');\n}\n\nif (win) {\n    win.global = win;\n    win.global._runningInNodeJS = false;\n} else if (root) {\n    root.global = root;\n    \n    // Polyfill browser APIs for Node.js\n    if (typeof root.window === 'undefined') {\n        // FileReader polyfill for Node.js\n        class NodeFileReader {\n            result: string | ArrayBuffer | null = null;\n            error: Error | null = null;\n            onload: ((this: NodeFileReader, ev: any) => any) | null = null;\n            onloadend: ((this: NodeFileReader, ev: any) => any) | null = null;\n            onerror: ((this: NodeFileReader, ev: any) => any) | null = null;\n\n            readAsDataURL(blob: Blob) {\n                blob.arrayBuffer().then(buffer => {\n                    const base64 = toBase64Url(buffer);\n                    const mimeType = (blob as any).type || 'application/octet-stream';\n                    this.result = `data:${mimeType};base64,${base64}`;\n                    if (this.onload) this.onload({ target: this });\n                    if (this.onloadend) this.onloadend({ target: this });\n                }).catch(err => {\n                    this.error = err;\n                    if (this.onerror) this.onerror({ target: this });\n                });\n            }\n\n            readAsArrayBuffer(blob: Blob) {\n                blob.arrayBuffer().then(buffer => {\n                    this.result = buffer;\n                    if (this.onload) this.onload({ target: this });\n                    if (this.onloadend) this.onloadend({ target: this });\n                }).catch(err => {\n                    this.error = err;\n                    if (this.onerror) this.onerror({ target: this });\n                });\n            }\n\n            readAsText(blob: Blob, encoding = 'utf-8') {\n                blob.text().then(text => {\n                    this.result = text;\n                    if (this.onload) this.onload({ target: this });\n                    if (this.onloadend) this.onloadend({ target: this });\n                }).catch(err => {\n                    this.error = err;\n                    if (this.onerror) this.onerror({ target: this });\n                });\n            }\n        }\n\n        root.FileReader = NodeFileReader;\n\n        // XMLHttpRequest polyfill for Node.js using node-fetch\n        class NodeXMLHttpRequest {\n            status: number = 0;\n            statusText: string = '';\n            readyState: number = 0;\n            responseText: string = '';\n            response: any = null;\n            responseType: string = '';\n            responseURL: string = '';\n            timeout: number = 0;\n            withCredentials: boolean = false;\n            \n            onload: ((this: NodeXMLHttpRequest, ev: any) => any) | null = null;\n            onerror: ((this: NodeXMLHttpRequest, ev: any) => any) | null = null;\n            onabort: ((this: NodeXMLHttpRequest, ev: any) => any) | null = null;\n            ontimeout: ((this: NodeXMLHttpRequest, ev: any) => any) | null = null;\n            onprogress: ((this: NodeXMLHttpRequest, ev: any) => any) | null = null;\n            onreadystatechange: ((this: NodeXMLHttpRequest, ev: any) => any) | null = null;\n            \n            upload: { onprogress: ((this: NodeXMLHttpRequest, ev: any) => any) | null } = { onprogress: null };\n\n            private _method: string = 'GET';\n            private _url: string = '';\n            private _headers: Record<string, string> = {};\n            private _aborted: boolean = false;\n\n            open(method: string, url: string) {\n                this._method = method;\n                this._url = url;\n                this.readyState = 1;\n            }\n\n            setRequestHeader(name: string, value: string) {\n                this._headers[name] = value;\n            }\n\n            getResponseHeader(name: string): string | null {\n                return null; // Simplified implementation\n            }\n\n            abort() {\n                this._aborted = true;\n                if (this.onabort) this.onabort({});\n            }\n\n            send(body?: any) {\n                if (this._aborted) return;\n                \n                const fetchOptions: RequestInit = {\n                    method: this._method,\n                    headers: this._headers,\n                };\n                \n                if (body && this._method !== 'GET' && this._method !== 'HEAD') {\n                    fetchOptions.body = body;\n                }\n\n                fetch(this._url, fetchOptions)\n                    .then(async response => {\n                        if (this._aborted) return;\n                        \n                        this.status = response.status;\n                        this.statusText = response.statusText;\n                        this.responseURL = response.url;\n                        this.readyState = 4;\n\n                        if (this.responseType === 'blob') {\n                            this.response = await response.blob();\n                        } else if (this.responseType === 'json') {\n                            try {\n                                this.response = await response.json();\n                            } catch {\n                                this.response = null;\n                            }\n                        } else if (this.responseType === 'arraybuffer') {\n                            this.response = await response.arrayBuffer();\n                        } else {\n                            this.responseText = await response.text();\n                            this.response = this.responseText;\n                        }\n\n                        if (this.onload) this.onload({});\n                    })\n                    .catch(error => {\n                        if (this._aborted) return;\n                        if (this.onerror) this.onerror(error);\n                    });\n            }\n        }\n\n        root.XMLHttpRequest = NodeXMLHttpRequest;\n\n        root.window = {\n            _runningInNodeJS: true,\n            alert: (message: string) => console.error('[Alert]', message),\n            sessionStorage: {\n                getItem: (key: string) => null,\n                setItem: (key: string, value: string) => {},\n                removeItem: (key: string) => {},\n            },\n            localStorage: {\n                getItem: (key: string) => {\n                    const fs = require('fs');\n                    const path = require('path');\n                    // read file \"{key}.skapi\" in ./states/localStorage/ as string\n                    try {\n                        const filePath = path.resolve(process.cwd(), 'states', 'localStorage', `${key}.skapi`);\n                        if (fs.existsSync(filePath)) {\n                            return fs.readFileSync(filePath, 'utf8');\n                        }\n                        return null;\n                    } catch (e) {\n                        return null;\n                    }\n                },\n                setItem: (key: string, value: string) => {\n                    const fs = require('fs');\n                    const path = require('path');\n                    // write file \"{key}.skapi\" in ./states/localStorage/ with value as content\n                    try {\n                        const dirPath = path.resolve(process.cwd(), 'states', 'localStorage');\n                        if (!fs.existsSync(dirPath)) {\n                            fs.mkdirSync(dirPath, { recursive: true });\n                        }\n                        const filePath = path.resolve(dirPath, `${key}.skapi`);\n                        fs.writeFileSync(filePath, value, 'utf8');\n                    } catch (e) {\n                        // ignore write errors\n                    }\n                },\n                removeItem: (key: string) => {\n                    const fs = require('fs');\n                    const path = require('path');\n                    try {\n                        const filePath = path.resolve(process.cwd(), 'states', 'localStorage', `${key}.skapi`);\n                        if (fs.existsSync(filePath)) {\n                            fs.unlinkSync(filePath);\n                        }\n                    } catch (e) {\n                        // ignore delete errors\n                    }\n                },\n            },\n            location: { \n                href: '', \n                origin: '', \n                hostname: '', \n                protocol: '', \n                replace: (url: string) => {} \n            },\n            navigator: { \n                userAgent: `nodejs/${root?.process?.versions?.node || 'unknown'}`,\n                mediaDevices: {\n                    getUserMedia: async (constraints: any) => {\n                        throw new Error('getUserMedia is not supported in Node.js environment.');\n                    }\n                }\n            },\n            addEventListener: () => {},\n            removeEventListener: () => {}\n        };\n    }\n}","export default class SkapiError extends Error {\n    code: string | number;\n    cause: Error;\n\n    constructor(\n        error: any,\n        options?: {\n            name?: string;\n            code?: string;\n            cause?: Error;\n        }) {\n\n        if (Array.isArray(error) && error.length <= 2) {\n            // \"code: msg\".split(':') => [\"code\", \"msg\"]\n\n            let msg = error[1];\n            if (error.length > 2) {\n                for (let i = 2; i < error.length; i++) {\n                    if (typeof error[i] === 'string') {\n                        msg += error[i];\n                    }\n                    else {\n                        break;\n                    }\n                }\n            }\n\n            super((msg || 'Something went wrong.').trim());\n            this.name = options?.name || \"SKAPI\";\n            this.code = options?.code || error[0] || \"ERROR\";\n            if (options?.cause) {\n                this.cause = options.cause;\n            }\n        }\n        else {\n            super((error?.message || ((typeof error === 'string') ? error : 'Something went wrong.')).trim());\n\n            if (typeof error === 'string') {\n                this.name = options?.name || \"SKAPI\";\n                this.code = options?.code || 'ERROR';\n                if (options?.cause) {\n                    this.cause = options.cause;\n                }\n            }\n\n            else if (error instanceof Error) {\n                this.cause = error;\n                this.name = error.name;\n                if (error.hasOwnProperty('code')) {\n                    this.code = (error as any).code;\n                }\n            }\n\n            else if (typeof error === 'object' && error?.code && error?.message) {\n                this.name = options?.name || \"SKAPI\";\n                this.code = options?.code || 'ERROR';\n                this.cause = error?.cause;\n            }\n        }\n    }\n}","import SkapiError from \"../main/error\";\n\nconst BASE62_ALPHABET = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz';\nconst BASE62 = BigInt(BASE62_ALPHABET.length);\nconst MAX_FORM_DATA_SIZE = 2 * 1024 * 1024;\nconst USER_ATTRIBUTE_EXCLUDES = ['aud', 'cognito:username', 'event_id', 'exp', 'iat', 'iss', 'jti', 'origin_jti', 'secret_key', 'token_use'];\nconst USER_ATTRIBUTE_CONVERTS = {\n    auth_time: 'log',\n    sub: 'user_id'\n};\nconst SERVICE_REGION_ALPHABET = [\n    '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a',\n    'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l'\n];\nconst SERVICE_REGION_KEYS = [\n    'us31', 'us72', 'ap51', 'ap22', 'ap41', 'eu71', 'ap21', 'us32', 'us71',\n    'af51', 'ap31', 'ap43', 'ap23', 'ap42', 'ca01', 'eu01', 'eu72', 'eu51',\n    'eu73', 'eu11', 'me51', 'sa31'\n];\n\nconst textEncoder = typeof TextEncoder !== 'undefined' ? new TextEncoder() : null;\n\nfunction getGlobalBuffer() {\n    if (typeof globalThis !== 'undefined') {\n        return (globalThis as any).Buffer;\n    }\n    return undefined;\n}\n\nfunction encodeUtf8(value: string): Uint8Array {\n    if (textEncoder) {\n        return textEncoder.encode(value);\n    }\n\n    const binary = unescape(encodeURIComponent(value));\n    const bytes = new Uint8Array(binary.length);\n    for (let i = 0; i < binary.length; i++) {\n        bytes[i] = binary.charCodeAt(i);\n    }\n    return bytes;\n}\n\nfunction toUint8Array(input: any): Uint8Array {\n    if (input instanceof Uint8Array) {\n        return input;\n    }\n    if (typeof input === 'string') {\n        return encodeUtf8(input);\n    }\n    if (typeof ArrayBuffer !== 'undefined' && input instanceof ArrayBuffer) {\n        return new Uint8Array(input);\n    }\n    if (typeof ArrayBuffer !== 'undefined' && ArrayBuffer.isView(input)) {\n        return new Uint8Array(input.buffer, input.byteOffset, input.byteLength);\n    }\n    if (Array.isArray(input)) {\n        return Uint8Array.from(input);\n    }\n\n    const BufferCtor = getGlobalBuffer();\n    if (BufferCtor) {\n        return new Uint8Array(BufferCtor.from(input));\n    }\n\n    throw new Error('No byte conversion available in this environment.');\n}\n\nclass MD5 {\n    private static readonly alphabet = '0123456789abcdef';\n\n    public static hash(str?: string): string {\n        if (typeof str !== 'string') {\n            console.warn('coercing non-string value to empty string');\n            str = '';\n        }\n\n        const x = MD5.sb(str);\n        let a = 1732584193;\n        let b = -271733879;\n        let c = -1732584194;\n        let d = 271733878;\n        let lastA;\n        let lastB;\n        let lastC;\n        let lastD;\n        for (let i = 0; i < x.length; i += 16) {\n            lastA = a;\n            lastB = b;\n            lastC = c;\n            lastD = d;\n\n            a = MD5.ff(a, b, c, d, x[i], 7, -680876936);\n            d = MD5.ff(d, a, b, c, x[i + 1], 12, -389564586);\n            c = MD5.ff(c, d, a, b, x[i + 2], 17, 606105819);\n            b = MD5.ff(b, c, d, a, x[i + 3], 22, -1044525330);\n            a = MD5.ff(a, b, c, d, x[i + 4], 7, -176418897);\n            d = MD5.ff(d, a, b, c, x[i + 5], 12, 1200080426);\n            c = MD5.ff(c, d, a, b, x[i + 6], 17, -1473231341);\n            b = MD5.ff(b, c, d, a, x[i + 7], 22, -45705983);\n            a = MD5.ff(a, b, c, d, x[i + 8], 7, 1770035416);\n            d = MD5.ff(d, a, b, c, x[i + 9], 12, -1958414417);\n            c = MD5.ff(c, d, a, b, x[i + 10], 17, -42063);\n            b = MD5.ff(b, c, d, a, x[i + 11], 22, -1990404162);\n            a = MD5.ff(a, b, c, d, x[i + 12], 7, 1804603682);\n            d = MD5.ff(d, a, b, c, x[i + 13], 12, -40341101);\n            c = MD5.ff(c, d, a, b, x[i + 14], 17, -1502002290);\n            b = MD5.ff(b, c, d, a, x[i + 15], 22, 1236535329);\n            a = MD5.gg(a, b, c, d, x[i + 1], 5, -165796510);\n            d = MD5.gg(d, a, b, c, x[i + 6], 9, -1069501632);\n            c = MD5.gg(c, d, a, b, x[i + 11], 14, 643717713);\n            b = MD5.gg(b, c, d, a, x[i], 20, -373897302);\n            a = MD5.gg(a, b, c, d, x[i + 5], 5, -701558691);\n            d = MD5.gg(d, a, b, c, x[i + 10], 9, 38016083);\n            c = MD5.gg(c, d, a, b, x[i + 15], 14, -660478335);\n            b = MD5.gg(b, c, d, a, x[i + 4], 20, -405537848);\n            a = MD5.gg(a, b, c, d, x[i + 9], 5, 568446438);\n            d = MD5.gg(d, a, b, c, x[i + 14], 9, -1019803690);\n            c = MD5.gg(c, d, a, b, x[i + 3], 14, -187363961);\n            b = MD5.gg(b, c, d, a, x[i + 8], 20, 1163531501);\n            a = MD5.gg(a, b, c, d, x[i + 13], 5, -1444681467);\n            d = MD5.gg(d, a, b, c, x[i + 2], 9, -51403784);\n            c = MD5.gg(c, d, a, b, x[i + 7], 14, 1735328473);\n            b = MD5.gg(b, c, d, a, x[i + 12], 20, -1926607734);\n            a = MD5.hh(a, b, c, d, x[i + 5], 4, -378558);\n            d = MD5.hh(d, a, b, c, x[i + 8], 11, -2022574463);\n            c = MD5.hh(c, d, a, b, x[i + 11], 16, 1839030562);\n            b = MD5.hh(b, c, d, a, x[i + 14], 23, -35309556);\n            a = MD5.hh(a, b, c, d, x[i + 1], 4, -1530992060);\n            d = MD5.hh(d, a, b, c, x[i + 4], 11, 1272893353);\n            c = MD5.hh(c, d, a, b, x[i + 7], 16, -155497632);\n            b = MD5.hh(b, c, d, a, x[i + 10], 23, -1094730640);\n            a = MD5.hh(a, b, c, d, x[i + 13], 4, 681279174);\n            d = MD5.hh(d, a, b, c, x[i], 11, -358537222);\n            c = MD5.hh(c, d, a, b, x[i + 3], 16, -722521979);\n            b = MD5.hh(b, c, d, a, x[i + 6], 23, 76029189);\n            a = MD5.hh(a, b, c, d, x[i + 9], 4, -640364487);\n            d = MD5.hh(d, a, b, c, x[i + 12], 11, -421815835);\n            c = MD5.hh(c, d, a, b, x[i + 15], 16, 530742520);\n            b = MD5.hh(b, c, d, a, x[i + 2], 23, -995338651);\n            a = MD5.ii(a, b, c, d, x[i], 6, -198630844);\n            d = MD5.ii(d, a, b, c, x[i + 7], 10, 1126891415);\n            c = MD5.ii(c, d, a, b, x[i + 14], 15, -1416354905);\n            b = MD5.ii(b, c, d, a, x[i + 5], 21, -57434055);\n            a = MD5.ii(a, b, c, d, x[i + 12], 6, 1700485571);\n            d = MD5.ii(d, a, b, c, x[i + 3], 10, -1894986606);\n            c = MD5.ii(c, d, a, b, x[i + 10], 15, -1051523);\n            b = MD5.ii(b, c, d, a, x[i + 1], 21, -2054922799);\n            a = MD5.ii(a, b, c, d, x[i + 8], 6, 1873313359);\n            d = MD5.ii(d, a, b, c, x[i + 15], 10, -30611744);\n            c = MD5.ii(c, d, a, b, x[i + 6], 15, -1560198380);\n            b = MD5.ii(b, c, d, a, x[i + 13], 21, 1309151649);\n            a = MD5.ii(a, b, c, d, x[i + 4], 6, -145523070);\n            d = MD5.ii(d, a, b, c, x[i + 11], 10, -1120210379);\n            c = MD5.ii(c, d, a, b, x[i + 2], 15, 718787259);\n            b = MD5.ii(b, c, d, a, x[i + 9], 21, -343485551);\n\n            a = MD5.ad(a, lastA);\n            b = MD5.ad(b, lastB);\n            c = MD5.ad(c, lastC);\n            d = MD5.ad(d, lastD);\n        }\n\n        return MD5.rh(a) + MD5.rh(b) + MD5.rh(c) + MD5.rh(d);\n    }\n\n    private static rh(n: number): string {\n        let s = '';\n        for (let j = 0; j <= 3; j++) {\n            s += MD5.alphabet.charAt((n >> (j * 8 + 4)) & 0x0F) + MD5.alphabet.charAt((n >> (j * 8)) & 0x0F);\n        }\n\n        return s;\n    }\n\n    private static ad(x: number, y: number): number {\n        const l = (x & 0xFFFF) + (y & 0xFFFF);\n        const m = (x >> 16) + (y >> 16) + (l >> 16);\n\n        return (m << 16) | (l & 0xFFFF);\n    }\n\n    private static rl(n: number, c: number): number {\n        return (n << c) | (n >>> (32 - c));\n    }\n\n    private static cm(q: number, a: number, b: number, x: number, s: number, t: number): number {\n        return MD5.ad(MD5.rl(MD5.ad(MD5.ad(a, q), MD5.ad(x, t)), s), b);\n    }\n\n    private static ff(a: number, b: number, c: number, d: number, x: number, s: number, t: number): number {\n        return MD5.cm(b & c | ~b & d, a, b, x, s, t);\n    }\n\n    private static gg(a: number, b: number, c: number, d: number, x: number, s: number, t: number): number {\n        return MD5.cm(b & d | c & ~d, a, b, x, s, t);\n    }\n\n    private static hh(a: number, b: number, c: number, d: number, x: number, s: number, t: number): number {\n        return MD5.cm(b ^ c ^ d, a, b, x, s, t);\n    }\n\n    private static ii(a: number, b: number, c: number, d: number, x: number, s: number, t: number): number {\n        return MD5.cm(c ^ (b | ~d), a, b, x, s, t);\n    }\n\n    private static sb(x: string): number[] {\n        let i;\n        const numBlocks = ((x.length + 8) >> 6) + 1;\n\n        const blocks = new Array(numBlocks * 16);\n        for (i = 0; i < numBlocks * 16; i++) {\n            blocks[i] = 0;\n        }\n\n        for (i = 0; i < x.length; i++) {\n            blocks[i >> 2] |= x.charCodeAt(i) << ((i % 4) * 8);\n        }\n\n        blocks[i >> 2] |= 0x80 << ((i % 4) * 8);\n        blocks[numBlocks * 16 - 2] = x.length * 8;\n\n        return blocks;\n    }\n}\n\nfunction toBase62(num: number): string {\n    if (num === 0) return BASE62_ALPHABET[0];\n    let result = '';\n    while (num > 0) {\n        result = BASE62_ALPHABET[num % 62] + result;\n        num = Math.floor(num / 62);\n    }\n    return result;\n}\n\nfunction fromBase62(chars: string): number {\n    return chars.split('').reverse().reduce((prev, curr, i) =>\n        prev + (BASE62_ALPHABET.indexOf(curr) * (62 ** i)), 0);\n}\n\nfunction generateRandom(length: number = 6): string {\n    let result = '';\n    const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\n    const charactersLength = characters.length;\n    let counter = 0;\n    while (counter < length) {\n        result += characters.charAt(Math.floor(Math.random() * charactersLength));\n        counter += 1;\n    }\n    return result;\n}\n\nfunction isNodeRuntime(): boolean {\n    return typeof window === 'undefined' || !!(window as any)?._runningInNodeJS;\n}\n\nfunction isBrowserRuntime(): boolean {\n    return !isNodeRuntime()\n        && typeof document !== 'undefined'\n        && typeof document.createElement === 'function';\n}\n\nfunction assertMaxFormDataSize(value: any): void {\n    let serialized: string;\n\n    try {\n        serialized = JSON.stringify(value);\n    }\n    catch (e) {\n        throw new SkapiError('Invalid data type.', { code: 'INVALID_REQUEST' });\n    }\n\n    if (new Blob([serialized]).size > MAX_FORM_DATA_SIZE) {\n        throw new SkapiError('Data should not exceed 2MB', { code: 'INVALID_REQUEST' });\n    }\n}\n\nfunction isDefaultTruthyInputValue(value: string): boolean {\n    return value === '' || value === 'on' || value === 'true';\n}\n\nfunction isDefaultFalsyInputValue(value: string): boolean {\n    return value === 'false';\n}\n\nfunction appendNamedElementValue(\n    data: Record<string, any>,\n    element: { name: string; value: string },\n    appendData: (data: Record<string, any>, key: string, value: any) => void\n): void {\n    if (element.name) {\n        appendData(data, element.name, element.value);\n    }\n}\n\n// Check if we're in a browser environment\nconst isBrowser = isBrowserRuntime();\nconst hasSubmitEvent = typeof SubmitEvent !== 'undefined';\nconst hasHTMLFormElement = typeof HTMLFormElement !== 'undefined';\n\nfunction extractFormData(\n    form: FormData | HTMLFormElement | SubmitEvent | { [key: string]: any } | number | string | boolean | null,\n    options?: {\n        nullIfEmpty?: boolean,\n        ignoreEmpty?: boolean,\n    },\n    callback?: (name: string, value: any) => any\n): { data: any, files: { name: string, file: File }[] } {\n    let data = {};\n    let files = [];\n\n    function appendData(data, key, val) {\n        if (options?.ignoreEmpty && val === '') {\n            return;\n        }\n        if (options?.nullIfEmpty && val === '') {\n            val = null;\n        }\n        if (typeof callback === 'function') {\n            let v = callback(key, val);\n            if (v !== undefined) {\n                val = v;\n            }\n        }\n        // key is a[b][c]\n        // a[b][c][0] when array\n        // if a[b][c] exists, then a[b][c] = [a[b][c], val]\n        let keys = key.split('[').map(k => {\n            let key = k.replace(']', '')\n            let numb = Number(key);\n            if (!isNaN(numb) && !key.includes('.')) {\n                key = numb;\n            }\n            else if (key[0] === '\"' && key[key.length - 1] === '\"' || key[0] === \"'\" && key[key.length - 1] === \"'\") {\n                key = key.replace(/\"/g, '').replace(/'/g, '');\n            }\n            return key;\n        });\n        let obj = data;\n        if (typeof keys[0] === 'number') {\n            throw new SkapiError('Form key cannot start with an array index.', { code: 'INVALID_REQUEST' });\n        }\n        for (let i = 0; i < keys.length; i++) {\n            let k = keys[i];\n            if (i < keys.length - 1) {\n                if (obj[k] === undefined) {\n                    let next = keys[i + 1];\n                    if (typeof next === 'number') {\n                        obj[k] = [];\n                    }\n                    else {\n                        obj[k] = {};\n                    }\n                }\n                obj = obj[k];\n            }\n            else {\n                if (obj[k] === undefined) {\n                    obj[k] = val;\n                }\n                else if (Array.isArray(obj[k])) {\n                    obj[k].push(val);\n                }\n                else {\n                    obj[k] = [obj[k], val];\n                }\n            }\n        }\n    }\n\n    function handleFile(files, name, v) {\n        if (v instanceof File) {\n            files.push({ name, file: v });\n        }\n        else if (v instanceof FileList) {\n            if (v && v.length > 0) {\n                for (let idx = 0; idx <= v.length - 1; idx++) {\n                    let file = v.item(idx)\n                    if (file) {\n                        files.push({ name, file });\n                    }\n                }\n            }\n        }\n    }\n\n    let handleInput = (i: HTMLInputElement) => {\n        if (i.name) {\n            if (i.type === 'number') {\n                if (i.value) {\n                    appendData(data, i.name, Number(i.value));\n                }\n            }\n            else if (i.type === 'checkbox' || i.type === 'radio') {\n                if (i.checked) {\n                    if ((i.type === 'checkbox' && i.value === '') || isDefaultTruthyInputValue(i.value)) {\n                        appendData(data, i.name, true);\n                    }\n                    else if (isDefaultFalsyInputValue(i.value)) {\n                        appendData(data, i.name, false);\n                    }\n                    else if (i.value) {\n                        appendData(data, i.name, i.value);\n                    }\n                }\n                else if (i.type === 'checkbox') {\n                    if (isDefaultTruthyInputValue(i.value)) {\n                        appendData(data, i.name, false);\n                    }\n                    else if (isDefaultFalsyInputValue(i.value)) {\n                        appendData(data, i.name, true);\n                    }\n                }\n            }\n            else if (i.type === 'file') {\n                if (i.files && i.files.length > 0) {\n                    handleFile(files, i.name, i.files);\n                }\n            }\n            else {\n                appendData(data, i.name, i.value);\n            }\n        }\n    }\n\n    if (isBrowser && (form instanceof HTMLInputElement || form instanceof HTMLSelectElement || form instanceof HTMLTextAreaElement)) {\n        handleInput(form as HTMLInputElement);\n        assertMaxFormDataSize(data);\n        return { data, files };\n    }\n\n    else {\n        if (isBrowser && form instanceof FormData) {\n            for (let pair of form.entries()) {\n                let name = pair[0];\n                let v = pair[1];\n                if ((v instanceof File) || ((v as any) instanceof FileList)) {\n                    handleFile(files, name, v);\n                }\n                else if ((v as any) instanceof Blob) {\n                    let j = v as any;\n                    if (j.type === 'application/json') {\n                        try {\n                            let json = JSON.parse(j.text());\n                            appendData(data, name, json);\n                        }\n                        catch (err) {\n                            appendData(data, name, j);\n                        }\n                    }\n                }\n                else {\n                    appendData(data, name, v);\n                }\n            }\n            assertMaxFormDataSize(data);\n            return { data, files };\n        }\n        if (isBrowser && hasSubmitEvent && form instanceof SubmitEvent) {\n            form = form.target;\n        }\n        if (isBrowser && hasHTMLFormElement && form instanceof HTMLFormElement) {\n            let inputs = form.querySelectorAll('input');\n            let selects = form.querySelectorAll('select');\n            let textarea = form.querySelectorAll('textarea');\n            for (let idx = 0; idx < selects.length; idx++) {\n                appendNamedElementValue(data, selects[idx], appendData);\n            }\n            for (let idx = 0; idx < textarea.length; idx++) {\n                appendNamedElementValue(data, textarea[idx], appendData);\n            }\n            for (let idx = 0; idx < inputs.length; idx++) {\n                handleInput(inputs[idx]);\n            }\n\n            assertMaxFormDataSize(data);\n            return { data, files };\n        }\n    }\n\n    assertMaxFormDataSize(form);\n\n    return { data: form, files };\n}\n\nfunction parseUserAttributes(attr: { [key: string]: any }) {\n    let user: any = {};\n    // parse attribute structure: [ { Name, Value }, ... ]\n    for (let name in attr) {\n        let value = attr[name];\n\n        if (USER_ATTRIBUTE_EXCLUDES.includes(name)) continue;\n\n        if (USER_ATTRIBUTE_CONVERTS[name]) {\n            user[USER_ATTRIBUTE_CONVERTS[name]] = value;\n        }\n\n        else if (name.includes('custom:')) {\n            // if (name === 'custom:service' && value !== this.service) {\n            //     throw new SkapiError('The user is not registered to the service.', { code: 'INVALID_REQUEST' });\n            // }\n            user[name.replace('custom:', '')] = value;\n        }\n\n        else if (name === 'address') {\n            let addr_main: any = value;\n            if (addr_main && typeof addr_main === 'object' && Object.keys(addr_main).length) {\n                if (addr_main?.formatted) {\n                    try {\n                        user[name] = JSON.parse(addr_main.formatted);\n                    }\n                    catch (err) {\n                        user[name] = addr_main.formatted;\n                    }\n                }\n            }\n            else {\n                user[name] = addr_main;\n            }\n        }\n        else {\n            user[name] = value;\n        }\n    }\n\n    for (let k of [\n        'address_public',\n        'birthdate_public',\n        'email_public',\n        'gender_public',\n        'phone_number_public',\n        'access_group'\n    ]) {\n        if (k.includes('_public')) {\n            if (user.hasOwnProperty(k.split('_')[0])) user[k] = user.hasOwnProperty(k) ? !!Number(user[k]) : false;\n            else delete user[k];\n        }\n        else user[k] = user.hasOwnProperty(k) ? Number(user[k]) : 0;\n    }\n\n    for (let k of [\n        'email',\n        'phone_number'\n    ]) {\n        if (user.hasOwnProperty(k)) {\n            user[k + '_verified'] = user[k + '_verified'] === true;\n        }\n        else {\n            delete user[k + '_verified'];\n        }\n    }\n\n    return user;\n}\n\nfunction decodeServiceId(service) {\n    service = decompressCompoundId(service); // validate format and throw if invalid\n    if (service.split(\"-\").length === 7) {\n        const idSplit = service.split(\"-\");\n        let region;\n        let owner;\n\n        try {\n            region = SERVICE_REGION_KEYS[fromBase62(idSplit[1][0])];\n            owner = idSplit.slice(2).join(\"-\");\n        }\n        catch (err) {\n            throw new Error('INVALID_PARAMETER: Service ID is invalid.');\n        }\n\n        if (!region) {\n            throw new Error('INVALID_PARAMETER: Service ID is invalid.');\n        }\n\n        return { service: region + idSplit[0] + idSplit[1].slice(1), owner };\n    }\n\n    return { service, owner: \"\" };\n}\n\nfunction formatServiceId(serviceId, ownerId) {\n    // format service ID\n    const regionIndex = SERVICE_REGION_KEYS.indexOf(serviceId.slice(0, 4));\n    const regionChar = SERVICE_REGION_ALPHABET[regionIndex];\n    const subRegionId = serviceId.slice(4, -4);\n\n    let formattedServiceId = `${subRegionId}-${regionChar}${serviceId.slice(-4)}-${ownerId}`;\n    return compressCompoundId(formattedServiceId);\n}\n\nfunction b62ToBigInt(str) {\n    let value = 0n;\n\n    for (const ch of str) {\n        const idx = BASE62_ALPHABET.indexOf(ch);\n        if (idx < 0) {\n            throw new Error(`INVALID_PARAMETER: Invalid base62 character: ${ch}`);\n        }\n        value = value * BASE62 + BigInt(idx);\n    }\n\n    return value;\n}\n\nfunction bigIntToB62(value, minLength = 1) {\n    if (value < 0n) {\n        throw new Error('INVALID_PARAMETER: Negative values are not supported.');\n    }\n\n    if (value === 0n) {\n        return '0'.repeat(Math.max(1, minLength));\n    }\n\n    let output = '';\n    let current = value;\n\n    while (current > 0n) {\n        const remainder = Number(current % BASE62);\n        output = BASE62_ALPHABET[remainder] + output;\n        current /= BASE62;\n    }\n\n    if (output.length < minLength) {\n        output = '0'.repeat(minLength - output.length) + output;\n    }\n\n    return output;\n}\n\nfunction bigIntToBytes(value) {\n    if (value === 0n) {\n        return Uint8Array.from([0]);\n    }\n\n    const bytes = [];\n    let current = value;\n\n    while (current > 0n) {\n        bytes.push(Number(current & 0xffn));\n        current >>= 8n;\n    }\n\n    bytes.reverse();\n    return Uint8Array.from(bytes);\n}\n\nfunction bytesToBigInt(buf) {\n    let value = 0n;\n\n    for (const b of buf) {\n        value = (value << 8n) + BigInt(b);\n    }\n\n    return value;\n}\n\nfunction uuidToBytes(uuid) {\n    const hex = String(uuid).replace(/-/g, '');\n\n    if (!/^[0-9a-fA-F]{32}$/.test(hex)) {\n        throw new Error('INVALID_PARAMETER: Invalid UUID format.');\n    }\n\n    const bytes = new Uint8Array(16);\n    for (let i = 0; i < 16; i++) {\n        bytes[i] = parseInt(hex.slice(i * 2, i * 2 + 2), 16);\n    }\n\n    return bytes;\n}\n\nfunction bytesToUuid(buf16) {\n    const hex = Array.from(toUint8Array(buf16), b => b.toString(16).padStart(2, '0')).join('');\n    return [\n        hex.slice(0, 8),\n        hex.slice(8, 12),\n        hex.slice(12, 16),\n        hex.slice(16, 20),\n        hex.slice(20)\n    ].join('-');\n}\n\n\nfunction compressCompoundId(input) {\n    const inputString = String(input);\n\n    if (inputString.split('-').length === 2) {\n        return inputString;\n    }\n\n    const match = inputString.match(/^([0-9A-Za-z]+)-([0-9A-Za-z]+)-([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12})$/);\n\n    if (!match) {\n        throw new Error('INVALID_PARAMETER: Input must match <base62>-<base62>-<uuid>.');\n    }\n\n    const [, firstPart, secondPart, uuid] = match;\n\n    if (firstPart.length < 2) {\n        throw new Error('INVALID_PARAMETER: The first part must contain at least 2 characters.');\n    }\n\n    if (secondPart.length >= BASE62_ALPHABET.length) {\n        throw new Error('INVALID_PARAMETER: The middle section is too long to encode.');\n    }\n\n    const movedPrefix = firstPart.slice(0, 2);\n    const movedFirstPart = firstPart.slice(2);\n    const movedMiddlePart = secondPart + movedPrefix;\n\n    // Part1 token format: [secondPartLength(base62:1char)][movedFirstPart][movedMiddlePart]\n    const part1 = BASE62_ALPHABET[secondPart.length] + movedFirstPart + movedMiddlePart;\n\n    const uuidBytes = uuidToBytes(uuid);\n    const part2 = bigIntToB62(bytesToBigInt(uuidBytes));\n\n    return `${part1}-${part2}`;\n}\n\nfunction decompressCompoundId(token) {\n    const tokenString = String(token);\n\n    if (tokenString.split('-').length !== 2) {\n        return tokenString;\n    }\n\n    const split = tokenString.split('-');\n\n    if (split.length !== 2 || !split[0] || !split[1]) {\n        throw new Error('INVALID_PARAMETER: Corrupt compressed token.');\n    }\n\n    const [part1, part2] = split;\n    const secondLength = BASE62_ALPHABET.indexOf(part1[0]);\n\n    if (secondLength < 0) {\n        throw new Error('INVALID_PARAMETER: Corrupt compressed token.');\n    }\n\n    const compacted = part1.slice(1);\n    const movedMiddleLength = secondLength + 2;\n\n    if (compacted.length < movedMiddleLength) {\n        throw new Error('INVALID_PARAMETER: Corrupt compressed token.');\n    }\n\n    const movedFirstPart = compacted.slice(0, compacted.length - movedMiddleLength);\n    const movedMiddlePart = compacted.slice(compacted.length - movedMiddleLength);\n\n    const movedPrefix = movedMiddlePart.slice(secondLength);\n    const secondPart = movedMiddlePart.slice(0, secondLength);\n    const firstPart = movedPrefix + movedFirstPart;\n\n    if (!/^[0-9A-Za-z]+$/.test(firstPart) || !/^[0-9A-Za-z]+$/.test(secondPart)) {\n        throw new Error('INVALID_PARAMETER: Corrupt compressed token.');\n    }\n\n    const uuidValue = b62ToBigInt(part2);\n    const uuidRaw = bigIntToBytes(uuidValue);\n\n    if (uuidRaw.length > 16) {\n        throw new Error('INVALID_PARAMETER: Corrupt compressed token.');\n    }\n\n    const uuidBytes = new Uint8Array(16);\n    uuidBytes.set(uuidRaw, 16 - uuidRaw.length);\n    const uuid = bytesToUuid(uuidBytes);\n\n    return `${firstPart}-${secondPart}-${uuid}`;\n}\n\n\nexport {\n    fromBase62,\n    toBase62,\n    isNodeRuntime,\n    isBrowserRuntime,\n    extractFormData,\n    MD5,\n    generateRandom,\n    parseUserAttributes,\n    compressCompoundId,\n    decompressCompoundId,\n    formatServiceId,\n    decodeServiceId\n};","\nimport SkapiError from '../main/error';\nimport { extractFormData } from './utils';\nimport cocochex from \"cocochex\";\n\nfunction UserId(id: string, param = 'User ID') {\n    // let uuid_regex = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-5][0-9a-f]{3}-[089ab][0-9a-f]{3}-[0-9a-f]{12}$/i;\n    // let uuid_regex = /^[0-9a-f]{8}-[0-9a-f]{4}-4[0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;\n    let uuid_regex = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i;\n    if (!id) {\n        throw new SkapiError(`${param} is empty.`, { code: 'INVALID_PARAMETER' });\n    }\n    else if (typeof id !== 'string') {\n        throw new SkapiError(`${param} should be type: string.`, { code: 'INVALID_PARAMETER' });\n    }\n    else if (!id.match(uuid_regex)) {\n        throw new SkapiError(`${param} is invalid.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    return id;\n}\n\nfunction PhoneNumber(value: string) {\n    if (value) {\n        if (typeof value !== 'string' || value.charAt(0) !== '+' || isNaN(Number(value.substring(1)))) {\n            throw new SkapiError('\"phone_number\" is invalid. The format should be \"+00123456789\". Type: string.', { code: 'INVALID_PARAMETER' });\n        }\n    }\n    return value || '';\n}\n\nfunction Birthdate(birthdate: string) {\n    // yyyy-mm-dd\n    if (birthdate) {\n        if (typeof birthdate !== 'string') {\n            throw new SkapiError('\"birthdate\" is invalid. The format should be \"yyyy-mm-dd\". Type: string.', { code: 'INVALID_PARAMETER' });\n        }\n\n        else {\n            let date_regex = new RegExp(/([12]\\d{3}-(0[1-9]|1[0-2])-(0[1-9]|[12]\\d|3[01]))/);\n            if (birthdate.length !== 10 || birthdate.split('-').length !== 3 || !date_regex.test(birthdate)) {\n                throw new SkapiError('\"birthdate\" is invalid. The format should be \"yyyy-mm-dd\". Type: string.', { code: 'INVALID_PARAMETER' });\n            }\n        }\n    }\n    return birthdate || '';\n}\n\nfunction Password(password: string) {\n    if (!password) {\n        throw new SkapiError('\"password\" is required.', { code: 'INVALID_PARAMETER' });\n    }\n    else if (typeof password !== 'string') {\n        throw new SkapiError('\"password\" should be type: string.', { code: 'INVALID_PARAMETER' });\n    }\n    else if (password.length < 6) {\n        throw new SkapiError('\"password\" should be at least 6 characters.', { code: 'INVALID_PARAMETER' });\n    }\n    else if (password.length > 60) {\n        throw new SkapiError('\"password\" can be up to 60 characters max.', { code: 'INVALID_PARAMETER' });\n    }\n\n    return password;\n}\n\nfunction Email(email: string, paramName: string = 'email') {\n    if (!email) {\n        throw new SkapiError(`\"${paramName}\" is required.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    else if (typeof email !== 'string') {\n        throw new SkapiError(`\"${paramName}\"should be type: string.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    else if (email.length < 5) {\n        throw new SkapiError(`\"${paramName}\" should be at least 5 characters.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    else if (/^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:\\.[a-zA-Z0-9-]+)*$/.test(email)) {\n        email = email.trim();\n        let splitAt = email.split('@');\n        let tld = splitAt[1].split('.');\n\n        if (tld.length >= 2) {\n            return email.toLowerCase();\n        }\n    }\n\n    throw new SkapiError(`\"${email}\" is an invalid email.`, { code: 'INVALID_PARAMETER' });\n}\n\nfunction Url(url: string | string[]) {\n    const hasWindow = typeof window !== 'undefined';\n    const baseUrl = (() => {\n        let baseUrl = hasWindow ? window.location.origin || null : null;\n        if (baseUrl && baseUrl.slice(-1) === '/') {\n            baseUrl = baseUrl.slice(0, -1);\n        }\n\n        return baseUrl;\n    })();\n    let check = (c: string) => {\n        if (typeof c === 'string') {\n            if (c === '*') {\n                return '*';\n            }\n            else {\n                let cu = c.trim();\n                if (cu[0] === '/' && baseUrl) {\n                    if (baseUrl.slice(0, 5) === 'file:') {\n                        throw new SkapiError(`\"${c}\" is an invalid url. Relative URL does not work on local file system. Use full URL string.`, { code: 'INVALID_PARAMETER' });\n                    }\n                    cu = baseUrl + cu;\n                }\n                else if (cu[0] === '.' && baseUrl) {\n                    if (baseUrl.slice(0, 5) === 'file:') {\n                        throw new SkapiError(`\"${c}\" is an invalid url. Relative URL does not work on local file system. Use full URL string.`, { code: 'INVALID_PARAMETER' });\n                    }\n                    let curr_loc = hasWindow ? window.location.href.split('?')[0] : '';\n                    if (curr_loc.slice(-1) !== '/') {\n                        curr_loc += '/';\n                    }\n\n                    cu = curr_loc + cu.slice(1);\n                }\n\n                let _url;\n\n                try {\n                    _url = new URL(cu);\n                }\n                catch (err) {\n                    throw new SkapiError(`\"${c}\" is an invalid url.`, { code: 'INVALID_PARAMETER' });\n                }\n\n                if (_url.protocol) {\n                    let url = _url.href;\n                    return url;\n                }\n            }\n        }\n\n        throw new SkapiError(`\"${c}\" is an invalid url.`, { code: 'INVALID_PARAMETER' });\n    };\n\n    if (Array.isArray(url)) {\n        return url.map(u => check(u));\n    }\n    else {\n        return check(url);\n    }\n}\n\nfunction Params<T = any>(\n    params: T,\n    struct: Record<string, any>,\n    required: string[] = [],\n    options?: {\n        ignoreEmpty?: boolean;\n        nullIfEmpty?: boolean;\n        precall?: (pre: { data: any, files: any }) => void\n    }\n): T {\n    // struct = {\n    //     a: 'type or value',\n    //     b: ['number', 'boolean', 'string', 'array', 'function', 'custom value', () => 'default value when none match, or is missing'],\n    //     c: (v: any) => { return 'value to assign'; }\n    // }\n    let ext = extractFormData(params, options);\n    let p = ext.data;\n    struct.service = 'string';\n    struct.owner = 'string';\n\n    let toCheck = {};\n\n    // Extra user input fields not in schema are ignored.\n    // If a field value is already a function, it copies it directly (JSON clone would break functions).\n    // For each allowed field, it tries to deep-copy via JSON stringify/parse so later validation/mutation does not mutate the original input object.\n    for (let s in struct) {\n        if (p && typeof p === 'object' && !Array.isArray(p) && p.hasOwnProperty(s)) {\n            if (typeof p[s] === 'function') {\n                toCheck[s] = p[s];\n            }\n            else {\n                try {\n                    toCheck[s] = JSON.parse(JSON.stringify(p[s]));\n                }\n                catch (err) {\n                    toCheck[s] = p[s];\n                }\n            }\n        }\n    }\n\n    if (options?.precall) {\n        options.precall({ data: toCheck, files: ext?.files || [] });\n    }\n\n    try {\n        return cocochex(toCheck, struct, required) as T;\n    }\n    catch (err: any) {\n        throw new SkapiError(err.message, { code: 'INVALID_PARAMETER' });\n    }\n}\n\nexport default {\n    UserId,\n    PhoneNumber,\n    Birthdate,\n    Password,\n    Email,\n    Url,\n    Params\n};","import SkapiError from '../main/error';\nimport {\n    CognitoUserAttribute,\n    CognitoUser,\n    AuthenticationDetails,\n    CognitoUserSession,\n    CognitoIdToken,\n    CognitoAccessToken,\n    CognitoRefreshToken\n} from 'amazon-cognito-identity-js';\nimport {\n    Form,\n    UserProfile,\n    FetchOptions,\n    DatabaseResponse,\n    UserAttributes,\n    UserPublic\n} from '../Types';\nimport validator from '../utils/validator';\nimport { request } from '../utils/network';\nimport { MD5, extractFormData, fromBase62, parseUserAttributes } from '../utils/utils';\n\nlet cognitoUser: CognitoUser | null = null;\n\nfunction map_ticket_obj(t): {\n    ticket_id?: string;\n    consume_id?: string;\n    user_id?: string;\n    is_test?: boolean;\n    timestamp?: number;\n    condition?: any;\n    action?: any;\n    count?: number;\n    time_to_live?: number;\n    description?: string;\n    limit_per_user?: number;\n} {\n    let mapper = {\n        \"tkid\": 'ticket_id',\n        \"cond\": 'condition',\n        \"stmp\": 'timestamp',\n        \"actn\": 'action',\n        \"cnt\": 'count',\n        \"ttl\": 'time_to_live',\n        'plch': 'placeholder',\n        'hash': 'hash',\n        'desc': 'description',\n        'pmc': 'limit_per_user'\n    }\n    let new_obj = {};\n    for (let k in t) {\n        if (k === 'tkid') {\n            let tkid = t[k].split('#');\n            if (tkid.length === 1) {\n                new_obj['ticket_id'] = tkid[0];\n                continue;\n            }\n            new_obj['ticket_id'] = tkid[1];\n            new_obj['consume_id'] = tkid[2];\n            new_obj['user_id'] = tkid[3];\n\n            // last 4 characters are random chars\n            let rand = tkid[2].slice(-4);\n            new_obj[\"is_test\"] = rand === \":CHK\";\n\n            if (!t.stmp) {\n                let timestampStr = tkid[2].slice(0, -4);\n\n                // check if timestampStr is a number string\n                if (/^[0-9]+$/.test(timestampStr)) {\n                    new_obj['timestamp'] = parseInt(timestampStr, 10);\n                }\n                else {\n                    new_obj['timestamp'] = fromBase62(tkid[2].slice(0, -4));\n                }\n            }\n        }\n        else if (mapper[k]) {\n            new_obj[mapper[k]] = t[k];\n        }\n        else {\n            new_obj[k] = t[k];\n        }\n    }\n    return new_obj;\n}\n\nexport async function consumeTicket(params: {\n    ticket_id: string;\n    method: string; // GET | POST\n    auth?: boolean;\n    data?: {\n        [key: string]: any;\n    }\n}): Promise<any> {\n    if (!params.ticket_id) {\n        throw new SkapiError('Ticket ID is required.', { code: 'INVALID_PARAMETER' });\n    }\n    if (!params.method) {\n        throw new SkapiError('Method is required. Should be either \"GET\" or \"POST\"', { code: 'INVALID_PARAMETER' });\n    }\n    let ticket_id = params.ticket_id;\n\n    await this.__connection;\n    let resp = await request.bind(this)(`https://${this.service.slice(0, 4)}.${this.customApiDomain}/auth/consume/${this.service}/${this.owner}/${ticket_id}`, params?.data || {}, { method: params.method, auth: !!params?.auth });\n    return map_ticket_obj(resp);\n}\n\nexport async function getTickets(params: {\n    ticket_id?: string;\n}, fetchOptions?: FetchOptions): Promise<DatabaseResponse<any[]>> {\n    await this.__connection;\n    let tickets = await request.bind(this)('ticket', Object.assign({ exec: 'list' }, params || {}), { auth: true, fetchOptions });\n    tickets.list = tickets.list.map(map_ticket_obj);\n    return tickets;\n}\n\nexport async function getConsumedTickets(params: {\n    ticket_id?: string;\n}, fetchOptions?: FetchOptions): Promise<DatabaseResponse<any[]>> {\n    await this.__connection;\n    let tickets = await request.bind(this)('ticket', Object.assign({ exec: 'consumed' }, params || {}), { auth: true, fetchOptions });\n    tickets.list = tickets.list.map(map_ticket_obj);\n    return tickets;\n}\n\nexport async function registerTicket(\n    params: {\n        ticket_id: string;\n        description: string;\n        count?: number;\n        time_to_live?: number;\n        placeholder?: { [key: string]: string };\n        limit_per_user?: number;\n        condition?: {\n            return200?: boolean; // When true, returns 200 when regardless condition mismatch\n            method?: 'GET' | 'POST'; // Defaults to 'GET' method when not given\n            headers?: {\n                key: string;\n                value: string | string[];\n                operator: 'gt' | 'gte' | 'lt' | 'lte' | 'eq' | 'ne' | '>' | '>=' | '<' | '<=' | '=' | '!=';\n            }[],\n            ip?: {\n                value: string | string[];\n                operator: 'gt' | 'gte' | 'lt' | 'lte' | 'eq' | 'ne' | '>' | '>=' | '<' | '<=' | '=' | '!=';\n            },\n            user_agent?: {\n                value: string | string[];\n                operator: 'gt' | 'gte' | 'lt' | 'lte' | 'eq' | 'ne' | '>' | '>=' | '<' | '<=' | '=' | '!=';\n            },\n            data?: {\n                key?: string;\n                value: any | any[];\n                operator: 'gt' | 'gte' | 'lt' | 'lte' | 'eq' | 'ne' | '>' | '>=' | '<' | '<=' | '=' | '!=';\n                setValueWhenMatch?: any | any[];\n            }[],\n            params?: {\n                key?: string;\n                value: string | string[];\n                operator: 'gt' | 'gte' | 'lt' | 'lte' | 'eq' | 'ne' | '>' | '>=' | '<' | '<=' | '=' | '!=';\n                setValueWhenMatch?: any | any[];\n            }[],\n            user?: {\n                key: string;\n                value: string | string[];\n                operator: 'gt' | 'gte' | 'lt' | 'lte' | 'eq' | 'ne' | '>' | '>=' | '<' | '<=' | '=' | '!=';\n            }[],\n            record_access?: string; // record id user should have access to\n            request?: {\n                url: string;\n                method: 'GET' | 'POST';\n                headers?: {\n                    [key: string]: string;\n                };\n                data?: Record<string, any>;\n                params?: Record<string, any>;\n                match: {\n                    key: string; // key[to][match]\n                    operator: 'gt' | 'gte' | 'lt' | 'lte' | 'eq' | 'ne' | '>' | '>=' | '<' | '<=' | '=' | '!=';\n                    value: any | any[];\n                }[];\n            }\n        };\n        action?: {\n            access_group: number; // group number to give access to the user\n            record_access?: string; // record id to give access to the user\n            request?: {\n                url: string;\n                method: 'GET' | 'POST'; // Defaults to 'GET' method when not given\n                headers?: {\n                    [key: string]: string;\n                };\n                data?: Record<string, any>;\n                params?: Record<string, any>;\n            }\n        };\n    }\n): Promise<string> {\n    return request.bind(this)('register-ticket', Object.assign({ exec: 'reg' }, params), { auth: true });\n}\n\nexport async function unregisterTicket(\n    params: {\n        ticket_id: string;\n    }\n): Promise<string> {\n    return request.bind(this)('register-ticket', Object.assign({ exec: 'unreg' }, params), { auth: true });\n}\n\nexport async function getJwtToken() {\n    await this.__connection;\n    // if (this.bearerToken) {\n    //     return this.bearerToken;\n    // }\n    if (this.session) {\n        const currentTime = Math.floor(Date.now() / 1000);\n        const idToken = this.session.getIdToken();\n        const idTokenExp = idToken.getExpiration();\n\n        if (idTokenExp < currentTime) {\n            this.log('request:requesting new token', null);\n            try {\n                await authentication.bind(this)().getSession({ refreshToken: true });\n                this.log('request:received new tokens', {\n                    exp: this.session?.idToken?.payload?.exp,\n                    currentTime,\n                    expiresIn: idTokenExp - currentTime,\n                    token: this.session?.accessToken?.jwtToken,\n                    refreshToken: this.session?.refreshToken?.token\n                });\n            }\n            catch (err) {\n                this.log('request:new token error', err);\n                throw new SkapiError('User login is required.', { code: 'INVALID_REQUEST' });\n            }\n        }\n        else {\n            this.log('request:tokens', {\n                exp: this.session.idToken.payload.exp,\n                currentTime,\n                expiresIn: idTokenExp - currentTime,\n                token: this.session.accessToken.jwtToken,\n                refreshToken: this.session.refreshToken.token\n            });\n        }\n        // this.bearerToken = this.session?.idToken?.jwtToken;\n        return this.session?.idToken?.jwtToken;\n    }\n    else {\n        this.log('request:no session', null);\n        _out.bind(this)();\n        throw new SkapiError('User login is required.', { code: 'INVALID_REQUEST' });\n    }\n}\n\nfunction refreshSession(session, cognitoUser) {\n    return new Promise((res, rej) => {\n        cognitoUser.refreshSession(session.getRefreshToken(), (refreshErr, refreshedSession) => {\n            this.log('getSession:refreshSessionCallback', { refreshErr, refreshedSession });\n\n            if (refreshErr) {\n                _out.bind(this)();\n                rej(refreshErr);\n            }\n            else if (refreshedSession.isValid()) {\n                res(refreshedSession);\n            }\n            else {\n                _out.bind(this)();\n                rej(new SkapiError('Invalid session.', { code: 'INVALID_REQUEST' }));\n            }\n        });\n    });\n}\n\nexport function authentication() {\n    if (!this.userPool) throw new SkapiError('User pool is missing', { code: 'INVALID_REQUEST' });\n\n    const getUserProfile = (): UserProfile => {\n        // get users updated attribute\n        let attr = cognitoUser.getSignInUserSession().getIdToken().payload || null;\n\n        // parse attribute structure: [ { Name, Value }, ... ]\n        let user = parseUserAttributes(attr);\n        this.log('normalized user attribute', user);\n        this.__user = user;\n        return user;\n    };\n\n    const getSession = async (option?: { skipUserUpdateEventTrigger?: boolean; refreshToken?: boolean; }): Promise<CognitoUserSession> =>\n        new Promise((res, rej) => {\n            // fetch session, updates user attributes\n            this.log('getSession:option', option);\n            let { refreshToken = false, skipUserUpdateEventTrigger = false } = option || {};\n            if (refreshToken && skipUserUpdateEventTrigger) {\n                skipUserUpdateEventTrigger = false;\n            }\n\n            // if (!this.bearerToken) {\n            cognitoUser = this.userPool.getCurrentUser();\n            // }\n            if (!cognitoUser) {\n                this.log('getSession:cognitoUser', cognitoUser);\n                // no user session. wasn't logged in.\n                _out.bind(this)();\n                rej(null);\n                return;\n            }\n\n            let respond = (s: any) => {\n                let sessionAttribute = s.getIdToken().payload;\n                this.log('getSession:respond:sessionAttribute', sessionAttribute);\n\n                if (sessionAttribute['custom:service'] !== this.service) {\n                    this.log('getSession:respond', 'invalid service, signing out');\n                    _out.bind(this)();\n                    throw new SkapiError('Invalid session.', { code: 'INVALID_REQUEST' });\n                }\n\n                this.session = s;\n                getUserProfile();\n                if (!skipUserUpdateEventTrigger) {\n                    this._runOnUserUpdateListeners(this.user);\n                }\n                return this.session;\n            }\n\n            cognitoUser.getSession((err: any, session: CognitoUserSession) => {\n                this.log('getSession:getSessionCallback', { err, session });\n                if (!session) {\n                    _out.bind(this)();\n                    rej(new SkapiError('Current session does not exist.', { code: 'INVALID_REQUEST' }));\n                    return;\n                }\n\n                if (err) {\n                    refreshSession.bind(this)(session, cognitoUser).then(r => res(respond(r))).catch(rej);\n                    return;\n                }\n\n                const currentTime = Math.floor(Date.now() / 1000);\n                const idToken = session.getIdToken();\n                const idTokenExp = idToken.getExpiration();\n                const isExpired = idTokenExp < currentTime;\n                this.log('getSession:currentTime', currentTime);\n                this.log('getSession:idTokenExp', idTokenExp);\n                this.log('getSession:isExpired', isExpired);\n                // if(this.bearerToken) {\n                this.log('getSession:existingBearerToken', this.bearerToken);\n                this.bearerToken = idToken.getJwtToken();\n                // }\n                // try refresh when invalid token\n                // when on updateProfile, it will always refreshToken\n                if (isExpired || refreshToken || !session.isValid()) {\n                    refreshSession.bind(this)(session, cognitoUser).then(r => res(respond(r))).catch(rej);\n                }\n                else {\n                    try {\n                        res(respond(session));\n                    }\n                    catch (err) {\n                        rej(err);\n                    }\n                }\n            });\n        });\n\n    const createCognitoUser = (un: string, raw?: boolean) => {\n        let username = raw ? un : un.includes(this.service + '-') ? un : this.service + '-' + MD5.hash(un);\n\n        return {\n            cognitoUser: new CognitoUser({\n                Username: username,\n                Pool: this.userPool\n            }),\n            cognitoUsername: username\n        };\n    };\n\n    const authenticateUser = (email: string, password: string, raw: boolean = false, is_openid: boolean = false): Promise<UserProfile> => {\n        return new Promise((res, rej) => {\n            this.__request_signup_confirmation = null;\n            this.__disabledAccount = null;\n\n            let initUser = createCognitoUser(email, raw);\n            let username = initUser.cognitoUsername;\n            let authenticationDetails = new AuthenticationDetails({\n                Username: username,\n                Password: password\n            });\n\n            initUser.cognitoUser.authenticateUser(authenticationDetails, {\n                newPasswordRequired: (userAttributes, requiredAttributes) => {\n                    this.__disabledAccount = null;\n                    this.__request_signup_confirmation = username;\n                    if (userAttributes['custom:signup_ticket'] === 'PASS' || userAttributes['custom:signup_ticket'] === 'MEMBER' || userAttributes['custom:signup_ticket'] === 'OIDPASS') {\n                        // auto confirm - (setting password from admin created account)\n                        initUser.cognitoUser.completeNewPasswordChallenge(password, {}, {\n                            onSuccess: _ => {\n                                cognitoUser = initUser.cognitoUser;\n                                getSession().then(session => res(this.user));\n                            },\n                            onFailure: (err: any) => {\n                                rej(new SkapiError(err.message || 'Failed to authenticate user.', { code: err.code }));\n                            }\n                        });\n                    }\n                    else {\n                        // legacy method... will be deprecated\n                        rej(new SkapiError(\"User's signup confirmation is required.\", { code: 'SIGNUP_CONFIRMATION_NEEDED' }));\n                    }\n                },\n                onSuccess: _ => getSession({ skipUserUpdateEventTrigger: true }).then(_ => {\n                    this.__disabledAccount = null;\n                    this._runOnLoginListeners(this.user);\n                    this._runOnUserUpdateListeners(this.user);\n                    res(this.user);\n                }),\n                onFailure: (err: any) => {\n                    let error = [];\n                    let { parsed, code } = cognitoErrorParser(err);\n                    let cognitoMessage = typeof err?.message === 'string' ? err.message : '';\n\n                    if (code === \"NotAuthorizedException\") {\n                        if (cognitoMessage.includes(\"User is disabled.\")) {\n                            this.__disabledAccount = username;\n                            error = ['This account is disabled.', 'USER_IS_DISABLED'];\n                        }\n\n                        else {\n                            if (is_openid) {\n                                error = ['The account already exists.', 'ACCOUNT_EXISTS'];\n                            }\n                            else {\n                                error = ['Incorrect username or password.', 'INCORRECT_USERNAME_OR_PASSWORD'];\n                            }\n                        }\n                    }\n                    else if (code === \"UserNotFoundException\") {\n                        error = ['Incorrect username or password.', 'INCORRECT_USERNAME_OR_PASSWORD'];\n                    }\n                    else if (code === \"UserNotConfirmedException\") {\n                        this.__request_signup_confirmation = username;\n                        error = [\"User's signup confirmation is required.\", 'SIGNUP_CONFIRMATION_NEEDED'];\n                    }\n                    else if (code === \"TooManyRequestsException\" || code === \"LimitExceededException\") {\n                        error = ['Too many attempts. Please try again later.', 'REQUEST_EXCEED'];\n                    }\n\n                    if (parsed.code === 'SIGNUP_CONFIRMATION_NEEDED') {\n                        this.__request_signup_confirmation = username;\n                    }\n\n                    if (error.length) {\n                        let errCode = error[1];\n                        let errMsg = error[0];\n\n                        // \"#INVALID_REQUEST: The account has been blacklisted.\"\n                        // \"#NOT_EXISTS: The account does not exist.\"\n                        // \"#SIGNUP_CONFIRMATION_NEEDED\": The account signup needs to be confirmed.\"\n                        // \"#ACCOUNT_EXISTS\": The account already exists.\"\n\n                        rej(new SkapiError(errMsg, { code: errCode, cause: err }));\n                    }\n                    else {\n                        rej(parsed);\n                    }\n\n                    return;\n                }\n            });\n        });\n    };\n\n    const signup = (username: string, password: string, attributes: CognitoUserAttribute[]) => {\n        return new Promise((res, rej) => {\n            this.userPool.signUp(username, password, attributes, null, (err, result) => {\n                if (err) {\n                    let { parsed, code } = cognitoErrorParser(err);\n                    let error = [];\n                    if (code === 'UsernameExistsException') {\n                        error = ['The account already exists.', 'EXISTS'];\n                    }\n                    else if (code === 'InvalidPasswordException') {\n                        error = ['Invalid password. Password must be at least 6 characters.', 'INVALID_PARAMETER'];\n                    }\n                    else if (code === 'InvalidParameterException') {\n                        error = [parsed.message || 'Invalid parameter.', 'INVALID_PARAMETER'];\n                    }\n                    else if (code === 'TooManyRequestsException' || code === 'LimitExceededException') {\n                        error = ['Too many attempts. Please try again later.', 'REQUEST_EXCEED'];\n                    }\n                    else if (code === 'CodeDeliveryFailureException') {\n                        error = ['Failed to deliver verification code.', 'CODE_DELIVERY_FAILURE'];\n                    }\n                    else if (code === 'UserLambdaValidationException') {\n                        error = [parsed.message || 'Signup validation failed.', 'INVALID_REQUEST'];\n                    }\n\n                    if (error.length) {\n                        rej(new SkapiError(error[0], { code: error[1], cause: err }));\n                    } else {\n                        rej(parsed);\n                    }\n\n                    return;\n                }\n                res(result);\n                return;\n            });\n        })\n    }\n\n    return {\n        getSession,\n        authenticateUser,\n        createCognitoUser,\n        signup\n    };\n}\nfunction cognitoErrorParser(err) {\n    let original_code = typeof err?.code === 'string' && err.code.trim() ? err.code.trim() : 'ERROR';\n\n    let raw_message =\n        typeof err?.message === 'string'\n            ? err.message\n            : (typeof err === 'string' ? err : 'An error occurred.');\n\n    let err_msg = (raw_message || 'An error occurred.').trim();\n    if (!err_msg) {\n        err_msg = 'An error occurred.';\n    }\n\n    // format: random text, #ERROR_CODE: Error message.\n    let custom = err_msg.match(/#([A-Za-z0-9_]+)\\s*:\\s*([\\s\\S]+)/);\n    let err_code = custom?.[1]?.trim() || original_code;\n    let err_msg_custom = custom?.[2]?.trim() || err_msg;\n\n    return {\n        parsed: new SkapiError(err_msg_custom, { code: err_code, cause: err }),\n        code: original_code,\n    }\n}\nexport async function getProfile(options?: { refreshToken: boolean; }): Promise<UserProfile | null> {\n    await this.__authConnection;\n    let refreshToken = options?.refreshToken || false;\n    if (!refreshToken) {\n        return this.user;\n    }\n    try {\n        // Always trigger live session refresh if refreshToken is true\n        await authentication.bind(this)().getSession(Object.assign({ skipUserUpdateEventTrigger: !refreshToken, refreshToken }, options));\n        return this.user;\n    } catch (err) {\n        return null;\n    }\n}\n\nexport async function openIdLogin(params: { token: string; id: string; merge?: boolean | string[] }): Promise<{ userProfile: UserProfile; openid: { [attribute: string]: string } }> {\n    await this.__connection;\n\n    params = validator.Params(params, {\n        token: 'string',\n        id: 'string',\n        merge: v => {\n            if (v === undefined) return false;\n            if (typeof v === 'string') {\n                return [v]\n            }\n            if (Array.isArray(v)) {\n                for (let item of v) {\n                    if (typeof item !== 'string') {\n                        throw new SkapiError('\"merge\" array items should be type: <string>.', { code: 'INVALID_PARAMETER' });\n                    }\n                }\n            }\n            if (typeof v !== 'boolean' && !Array.isArray(v)) {\n                throw new SkapiError('\"merge\" should be type: <boolean | string[]>.', { code: 'INVALID_PARAMETER' });\n            }\n            return v;\n        }\n    });\n\n    let oplog = await request.bind(this)(\"openid-logger\", params);\n    let logger = oplog.logger.split('#');\n    let username = this.service + '-' + logger[0];\n    let password = logger[1];\n\n    return { userProfile: await authentication.bind(this)().authenticateUser(username, password, true, true), openid: oplog.openid };\n}\n\n// Get user info from base64 encoded token\nfunction decodeBase64Utf8(base64: string): string {\n    const root = typeof globalThis !== 'undefined' ? (globalThis as any) : undefined;\n\n    if (root?.Buffer) {\n        return root.Buffer.from(base64, 'base64').toString('utf8');\n    }\n\n    if (typeof atob === 'function') {\n        const binary = atob(base64);\n        const bytes = new Uint8Array(binary.length);\n        for (let i = 0; i < binary.length; i++) {\n            bytes[i] = binary.charCodeAt(i);\n        }\n\n        if (typeof TextDecoder !== 'undefined') {\n            return new TextDecoder().decode(bytes);\n        }\n\n        return binary;\n    }\n\n    throw new Error('No base64 decoder available in this environment');\n}\n\nfunction getUserFromToken(accessToken) {\n    // JWT has 3 parts: header.payload.signature\n    const parts = accessToken.split('.');\n    if (parts.length !== 3) {\n        throw new Error('Invalid JWT format');\n    }\n\n    // Decode the payload (second part) - use base64url decoding\n    const payload = parts[1];\n    // Replace base64url chars with standard base64 chars\n    const base64 = payload.replace(/-/g, '+').replace(/_/g, '/');\n    const decoded = decodeBase64Utf8(base64);\n    const userData = JSON.parse(decoded);\n    return userData;\n}\n\nexport async function loginWithToken(params: {\n    idToken: string;\n    accessToken?: string;\n    refreshToken?: string;\n}): Promise<UserProfile> {\n    await this.__authConnection;\n    this.log('loginWithToken:params', params);\n    params = validator.Params(params, {\n        idToken: 'string',\n        accessToken: 'string',\n        refreshToken: 'string'\n    }, ['idToken']);\n\n    // Store the bearer token for authenticated requests\n    const idTokenPayload = getUserFromToken(params.idToken);\n    this.log('loginWithToken:idTokenPayload', idTokenPayload);\n    // Validate the token belongs to this service\n    if (idTokenPayload['custom:service'] !== this.service) {\n        throw new SkapiError('Token does not belong to this service.', { code: 'INVALID_REQUEST' });\n    }\n\n    // Check if token is expired\n    const currentTime = Math.floor(Date.now() / 1000);\n    if (idTokenPayload.exp && idTokenPayload.exp < currentTime) {\n        throw new SkapiError('Token has expired.', { code: 'INVALID_REQUEST' });\n    }\n\n    // this.bearerToken = params.idToken;\n    // Parse user attributes from the token payload\n    this.__user = parseUserAttributes(idTokenPayload);\n\n    this.session = null;\n\n    if (params.accessToken && params.refreshToken) {\n        try {\n            this.session = new CognitoUserSession({\n                IdToken: new CognitoIdToken({ IdToken: params.idToken }),\n                AccessToken: new CognitoAccessToken({ AccessToken: params.accessToken }),\n                RefreshToken: new CognitoRefreshToken({ RefreshToken: params.refreshToken })\n            });\n\n            this.log('loginWithToken:session', this.session);\n            this.log('loginWithToken:CognitoUser', CognitoUser);\n            this.log('loginWithToken:userPool', this.userPool);\n            // Restore cognitoUser in memory for Node.js/server context\n            if (CognitoUser && this.userPool) {\n                this.log('loginWithToken:cognito:username', idTokenPayload['cognito:username']);\n                let up = {\n                    Username: idTokenPayload['cognito:username'],\n                    Pool: this.userPool\n                }\n                this.log('loginWithToken:cognitoUserParams', up);\n                cognitoUser = new CognitoUser(up);\n                cognitoUser.setSignInUserSession(this.session);\n                this.log('loginWithToken:cognitoUserRestored', {\n                    cognitoUserType: typeof cognitoUser,\n                    cognitoUserKeys: Object.keys(cognitoUser || {}),\n                    cognitoUser\n                });\n            }\n        }\n        catch (err: any) {\n            // Enhanced error logging: log all property names, symbols, and descriptors\n            this.log('loginWithToken:err', err);\n            try {\n                this.log('loginWithToken:err:stringified', JSON.stringify(err));\n            } catch (e) {\n                this.log('loginWithToken:err:stringifyFail', String(err));\n            }\n            try {\n                const keys = Object.keys(err || {});\n                const symbols = Object.getOwnPropertySymbols ? Object.getOwnPropertySymbols(err || {}) : [];\n                const descriptors = Object.getOwnPropertyDescriptors ? Object.getOwnPropertyDescriptors(err || {}) : {};\n                this.log('loginWithToken:createSessionError:allKeys', { keys, symbols, descriptors });\n            } catch (e) {\n                this.log('loginWithToken:createSessionError:allKeysFail', String(e));\n            }\n        }\n    }\n\n    this._runOnLoginListeners(this.user);\n    this._runOnUserUpdateListeners(this.user);\n\n    return this.user;\n}\n\nexport async function checkAdmin() {\n    await this.__connection;\n    if (this.__user?.service === this.service) {\n        // logged in\n        return this.__user?.owner === this.host;\n    } else {\n        // not logged\n        await logout.bind(this)();\n    }\n\n    return false;\n}\n\nexport async function _out(global: boolean = false) {\n    let toReturn = null;\n\n    if (cognitoUser) {\n        if (global) {\n            toReturn = new Promise((res, rej) => {\n                cognitoUser.globalSignOut({\n                    onSuccess: (result: any) => {\n                        this.log('globalSignOut:success', result);\n                        res(result);\n                    },\n                    onFailure: (err: any) => {\n                        this.log('globalSignOut:error', err);\n                        rej(err);\n                    }\n                });\n            });\n        }\n        else {\n            cognitoUser.signOut();\n        }\n    }\n\n    let to_be_erased = {\n        'session': null,\n        '__startKeyHistory': {},\n        '__cached_requests': {},\n        '__user': null\n    };\n\n    if (toReturn) {\n        toReturn = await toReturn;\n    }\n\n    for (let k in to_be_erased) {\n        this[k] = to_be_erased[k];\n    }\n\n    this._runOnUserUpdateListeners(null);\n    this._runOnLoginListeners(null);\n\n    return toReturn;\n}\n\nexport async function logout(params?: Form<{ global: boolean; }>): Promise<'SUCCESS: The user has been logged out.'> {\n    await this.__connection;\n\n    let { data } = extractFormData(params);\n\n    await _out.bind(this)(data?.global);\n    return 'SUCCESS: The user has been logged out.';\n}\n\nexport async function resendSignupConfirmation(): Promise<'SUCCESS: Signup confirmation e-mail has been sent.'> {\n    if (!this.__request_signup_confirmation) {\n        throw new SkapiError('Least one login attempt is required.', { code: 'INVALID_REQUEST' });\n    }\n\n    let resend = await request.bind(this)(\"confirm-signup\", {\n        username: this.__request_signup_confirmation,\n    });\n\n    return resend; // 'SUCCESS: Signup confirmation e-mail has been sent.'\n}\n\nexport async function recoverAccount(\n    /** Redirect url on confirmation success. */\n    redirect: boolean | string = false\n): Promise<\"SUCCESS: Recovery e-mail has been sent.\"> {\n\n    if (typeof redirect === 'string') {\n        redirect = validator.Url(redirect);\n    }\n\n    else if (typeof redirect !== 'boolean') {\n        throw new SkapiError('Argument should be type: <boolean | string>.', { code: 'INVALID_REQUEST' });\n    }\n\n    if (!this.__disabledAccount) {\n        throw new SkapiError('Least one signin attempt of disabled account is required.', { code: 'INVALID_REQUEST' });\n    }\n\n    await request.bind(this)(\"recover-account\", { username: this.__disabledAccount, redirect });\n    return 'SUCCESS: Recovery e-mail has been sent.';\n}\n\nexport async function login(\n    form: Form<{\n        /** if given, username will be used instead of email. */\n        username?: string;\n        /** E-Mail for signin. 64 character max. */\n        email: string;\n        /** Password for signin. Should be at least 6 characters. */\n        password: string;\n    }>): Promise<UserProfile> {\n        \n    let params:any = validator.Params(form, {\n        username: 'string',\n        email: 'string',\n        password: 'string'\n    }, ['password']);\n\n    await this.__authConnection;\n\n    if (params.email) {\n        // incase user uses email instead of username\n        try {\n            validator.Email(params.email);\n        } catch (err) {\n            params.username = params.email;\n            delete params.email;\n        }\n    }\n\n    if (!params.username && !params.email) {\n        throw new SkapiError('Least one of \"username\" or \"email\" is required.', { code: 'INVALID_PARAMETER' });\n    }\n\n    const resolved = await authentication.bind(this)().authenticateUser(params.username || params.email, params.password);\n\n    return resolved;\n    // INVALID_REQUEST: the account has been blacklisted.\n    // NOT_EXISTS: the account does not exist.\n}\n\nexport async function signup(\n    form: Form<UserAttributes & { password: String; username?: string; }>,\n    option?: {\n        signup_confirmation?: boolean | string;\n        email_subscription?: boolean;\n        login?: boolean;\n    }): Promise<UserProfile | \"SUCCESS: The account has been created. User's signup confirmation is required.\" | 'SUCCESS: The account has been created.'> {\n\n    await this.__authConnection;\n\n    let paramRestrictions = {\n        username: 'string',\n        password: (v: string) => validator.Password(v),\n\n        email: (v: string) => validator.Email(v),\n        name: 'string',\n        address: (v: any) => {\n            if (!v) return '';\n\n            if (typeof v === 'string') {\n                return v;\n            }\n\n            if (typeof v === 'object') {\n                return JSON.stringify(v);\n            }\n\n            return undefined;\n        },\n        gender: 'string',\n        birthdate: (v: string) => v ? validator.Birthdate(v) : \"\",\n        phone_number: (v: string) => v ? validator.PhoneNumber(v) : \"\",\n\n        email_public: ['boolean', () => false],\n        address_public: ['boolean', () => false],\n        gender_public: ['boolean', () => false],\n        birthdate_public: ['boolean', () => false],\n        phone_number_public: ['boolean', () => false],\n        access_group: 'number', // v=>{if(v > 0 && v < 100) return v else throw SkapiError(...)}\n        misc: 'string',\n\n        picture: (v: string) => { if (v) return validator.Url(v); else return \"\" },\n        profile: (v: string) => { if (v) return validator.Url(v); else return \"\" },\n        family_name: 'string',\n        given_name: 'string',\n        middle_name: 'string',\n        nickname: 'string',\n        website: (v: string) => { if (v) return validator.Url(v); else return \"\" },\n    };\n\n    let params = validator.Params(form || {}, paramRestrictions, ['email', 'password']);\n\n    // always logout before creating an account (for users)\n    await logout.bind(this)();\n\n    option = validator.Params(option || {}, {\n        email_subscription: (v: boolean) => {\n            if (typeof v !== 'boolean') {\n                throw new SkapiError('\"option.email_subscription\" should be type: <boolean>.', { code: 'INVALID_PARAMETER' });\n            }\n            if (!option?.signup_confirmation) {\n                // requires to be url or true\n                throw new SkapiError('\"option.signup_confirmation\" is required for email subscription.', { code: 'INVALID_PARAMETER' });\n            }\n            return v;\n        },\n        signup_confirmation: (v: string | boolean) => {\n            let value = v;\n            if (typeof v === 'string') {\n                value = validator.Url(v);\n            }\n            else if (typeof v === 'boolean') {\n                value = v;\n            }\n            else {\n                throw new SkapiError('\"option.signup_confirmation\" should be type: <string | boolean>.', { code: 'INVALID_PARAMETER' });\n            }\n\n            if (value && !params.email) {\n                throw new SkapiError('\"email\" is required for signup confirmation.', { code: 'INVALID_PARAMETER' });\n            }\n\n            return value;\n        },\n        login: (v: boolean) => {\n            if (typeof v === 'boolean') {\n                if (option.signup_confirmation && v) {\n                    throw new SkapiError('\"login\" is not allowed when \"option.signup_confirmation\" is true.', { code: 'INVALID_PARAMETER' });\n                }\n                return v;\n            }\n            throw new SkapiError('\"option.login\" should be type: boolean.', { code: 'INVALID_PARAMETER' });\n        }\n    });\n\n    let logUser = option?.login || false;\n\n    params.signup_confirmation = option?.signup_confirmation || false;;\n    params.email_subscription = option?.email_subscription || false;\n\n    if (params.email_public && !params.signup_confirmation) {\n        throw new SkapiError('\"option.signup_confirmation\" should be true if \"email_public\" is set to true.', { code: 'INVALID_PARAMETER' });\n    }\n\n    // cognito signup process below\n\n    params.service = this.service;\n    params.owner = this.owner;\n\n    // user creating account\n    let newUser = authentication.bind(this)().createCognitoUser(params.username || params.email);\n\n    for (let k of ['email_public',\n        'address_public',\n        'gender_public',\n        'birthdate_public',\n        'phone_number_public']) {\n        params[k] = params[k] ? '1' : '0';\n    }\n\n    if (params.access_group) {\n        params.access_group = params.access_group.toString();\n    }\n\n    let signup_key = (await request.bind(this)('signupkey', {\n        username: newUser.cognitoUsername,\n        signup_confirmation: typeof params.signup_confirmation === 'boolean' ? JSON.stringify(params.signup_confirmation) : params.signup_confirmation,\n        email_subscription: params.email_subscription,\n    })).split(':');\n\n    let signup_ticket = signup_key.slice(1).join(':');\n\n    let attributeList = [\n        new CognitoUserAttribute({\n            Name: 'custom:signup',\n            Value: signup_key[0]\n        }),\n        new CognitoUserAttribute({\n            Name: 'locale',\n            Value: signup_ticket.split('#')[1]\n        }),\n        new CognitoUserAttribute({\n            Name: 'custom:signup_ticket',\n            Value: signup_ticket\n        })\n    ];\n\n    for (let k in paramRestrictions) {\n        let customParams = [\n            'email_public',\n            'address_public',\n            'gender_public',\n            'birthdate_public',\n            'phone_number_public',\n            'misc',\n            'service',\n            'owner'\n        ];\n        if (params[k] === \"\") {\n            continue;\n        }\n\n        if (k === 'username' || k === 'password' || k === 'access_group') {\n            continue;\n        }\n\n        if (customParams.includes(k)) {\n            attributeList.push(new CognitoUserAttribute({\n                Name: 'custom:' + k,\n                Value: params[k]\n            }));\n        }\n        else {\n            attributeList.push(new CognitoUserAttribute({\n                Name: k,\n                Value: params[k]\n            }));\n        }\n    }\n\n    await authentication.bind(this)().signup(newUser.cognitoUsername, params.password, attributeList);\n\n    if (params.signup_confirmation) {\n        cognitoUser = newUser.cognitoUser;\n        this.__request_signup_confirmation = newUser.cognitoUsername;\n        return \"SUCCESS: The account has been created. User's signup confirmation is required.\";\n    }\n    else if (logUser) {\n        // log user in\n        return login.bind(this)({ email: params.username || params.email, password: params.password });\n    }\n\n    return 'SUCCESS: The account has been created.';\n}\n\nexport async function disableAccount(): Promise<'SUCCESS: account has been disabled.'> {\n    await this.__connection;\n    let result = await request.bind(this)('remove-account', { disable: this.__user.user_id }, { auth: true });\n    await logout.bind(this)();\n    return result;\n}\n\nexport async function resetPassword(form: Form<{\n    email: string;\n    code: string | number;\n    new_password: string;\n}>): Promise<\"SUCCESS: New password has been set.\"> {\n\n    await this.__connection;\n\n    let params = validator.Params(form, {\n        email: (v: string) => validator.Email(v),\n        code: ['number', 'string'],\n        new_password: (v: string) => validator.Password(v)\n    }, ['email', 'code', 'new_password']);\n\n    let code = params.code, new_password = params.new_password;\n\n    if (typeof code === 'number') {\n        code = code.toString();\n    }\n\n    return new Promise(async (res, rej) => {\n        let cognitoUser = authentication.bind(this)().createCognitoUser(params.email).cognitoUser;\n\n        cognitoUser.confirmPassword(code, new_password, {\n            onSuccess: result => {\n                res(\"SUCCESS: New password has been set.\");\n            },\n            onFailure: (err: any) => {\n                rej(new SkapiError(err?.message || 'Failed to reset password.', { code: err?.code || 'ERROR', cause: err }));\n            }\n        });\n    });\n}\n\nasync function verifyAttribute(attribute: string, form: Form<{ code: string; }>): Promise<string> {\n    await this.__connection;\n    let code: string;\n\n    if (!cognitoUser) {\n        throw new SkapiError('The user has to be logged in.', { code: 'INVALID_REQUEST' });\n    }\n\n    if (attribute === 'email' || attribute === 'phone_number') {\n        if (!this.__user.hasOwnProperty(attribute)) {\n            throw new SkapiError(`No ${attribute === 'email' ? 'e-mail' : 'phone number'} to verify`, { code: 'INVALID_REQUEST' });\n        }\n\n        if (this.__user?.[`${attribute}_verified`]) {\n            return `SUCCESS: \"${attribute}\" is verified.`;\n        }\n\n        code = (form ? validator.Params(form, {\n            code: 'string'\n        }) : {}).code || '';\n    }\n    else {\n        return;\n    }\n\n    return new Promise((res, rej) => {\n        let callback: any = {\n            onSuccess: (result: any) => {\n                if (code) {\n                    authentication.bind(this)().getSession({ refreshToken: true }).then(\n                        () => {\n                            if (this.__user) {\n                                this.__user[attribute + '_verified'] = true;\n                            }\n                            res(`SUCCESS: \"${attribute}\" is verified.`);\n                        }\n                    ).catch(err => {\n                        rej(err);\n                    });\n                }\n\n                else {\n                    res('SUCCESS: Verification code has been sent.');\n                }\n            },\n            onFailure: (err: Record<string, any>) => {\n                rej(\n                    new SkapiError(\n                        err.message || 'Failed to request verification code.',\n                        {\n                            code: err?.code\n                        }\n                    )\n                );\n            }\n        };\n\n        if (code) {\n            cognitoUser?.verifyAttribute(attribute, code, callback);\n        }\n        else {\n            callback.inputVerificationCode = null;\n            cognitoUser?.getAttributeVerificationCode(attribute, callback);\n        }\n    });\n}\n\nexport function verifyPhoneNumber(form?: Form<{ code: string; }>): Promise<string> {\n    // 'SUCCESS: Verification code has been sent.' | 'SUCCESS: \"phone_number\" is verified.'\n    return verifyAttribute.bind(this)('phone_number', form);\n}\n\nexport function verifyEmail(form?: Form<{ code: string; }>): Promise<string> {\n    // 'SUCCESS: Verification code has been sent.' | 'SUCCESS: \"email\" is verified.'\n    return verifyAttribute.bind(this)('email', form);\n}\n\nexport async function forgotPassword(\n    form: Form<{\n        /** Signin E-Mail. */\n        email: string;\n    }>): Promise<\"SUCCESS: Verification code has been sent.\"> {\n\n    await this.__connection;\n\n    let params = validator.Params(form, {\n        email: (v: string) => validator.Email(v)\n    }, ['email']);\n\n    return new Promise(async (res, rej) => {\n        let cognitoUser = authentication.bind(this)().createCognitoUser(params.email).cognitoUser;\n        cognitoUser.forgotPassword({\n            onSuccess: result => {\n                res(\"SUCCESS: Verification code has been sent.\");\n            },\n            onFailure: (err: any) => {\n                // create SkapiError from err\n                /*\n                UserNotFoundException\tUser does not exist in the user pool\n                InvalidParameterException\tInvalid parameter (e.g., missing required attribute)\n                NotAuthorizedException\tUser is not authorized (e.g., user is disabled)\n                LimitExceededException\tAttempt limit exceeded, try again later\n                TooManyRequestsException\tToo many requests made to the API\n                CodeDeliveryFailureException\tFailed to deliver the verification code (email/SMS issue)\n                UnexpectedLambdaException\tUnexpected exception with Lambda trigger\n                UserLambdaValidationException\tUser validation exception from Lambda trigger\n                InvalidLambdaResponseException\tInvalid response from Lambda trigger\n                InvalidSmsRoleAccessPolicyException\tInvalid SMS role access policy\n                InvalidSmsRoleTrustRelationshipException\tInvalid SMS role trust relationship\n                InvalidEmailRoleAccessPolicyException\tInvalid email role access policy\n                ResourceNotFoundException\tResource not found (user pool doesn't exist)\n                InternalErrorException\tInternal server error\n                ForbiddenException\tWAF blocked the request\n                */\n\n                let { parsed, code } = cognitoErrorParser(err);\n\n                let mappedCode = {\n                    UserNotFoundException: 'NOT_EXISTS',\n                    InvalidParameterException: 'INVALID_PARAMETER',\n                    NotAuthorizedException: 'INVALID_REQUEST',\n                    LimitExceededException: 'REQUEST_EXCEED',\n                    TooManyRequestsException: 'REQUEST_EXCEED',\n                    CodeDeliveryFailureException: 'CODE_DELIVERY_FAILURE'\n                }[code] || parsed.code || code || 'ERROR';\n\n                rej(new SkapiError(parsed.message, { code: mappedCode, cause: err }));\n            }\n        });\n    });\n}\n\nexport async function changePassword(params: {\n    new_password: string;\n    current_password: string;\n}): Promise<'SUCCESS: Password has been changed.'> {\n    await this.__connection;\n    if (!this.session) {\n        throw new SkapiError('User login is required.', { code: 'INVALID_REQUEST' });\n    }\n\n    let p = validator.Params(params, {\n        'current_password': 'string',\n        'new_password': 'string'\n    });\n\n    if (!p?.current_password) {\n        throw new SkapiError('\"current_password\" is required to change password.', { code: 'INVALID_PARAMETER' });\n    }\n\n    if (!p?.new_password) {\n        throw new SkapiError('\"new_password\" is required to change password.', { code: 'INVALID_PARAMETER' });\n    }\n\n    validator.Password(p.current_password);\n    validator.Password(p.new_password);\n\n    return new Promise((res, rej) => {\n        cognitoUser.changePassword(\n            p.current_password,\n            p.new_password,\n            (err: any, result: any) => {\n                if (err) {\n                    if (err?.code === \"InvalidParameterException\") {\n                        rej(new SkapiError('Invalid password parameter.', { code: 'INVALID_PARAMETER' }));\n                    }\n                    else if (err?.code === \"NotAuthorizedException\") {\n                        rej(new SkapiError('Incorrect password.', { code: 'INVALID_REQUEST' }));\n                    }\n                    else if (err?.code === \"TooManyRequestsException\" || err?.code === \"LimitExceededException\") {\n                        rej(new SkapiError('Too many attempts. Please try again later.', { code: 'REQUEST_EXCEED' }));\n                    }\n                    else {\n                        let { parsed, code } = cognitoErrorParser(err);\n                        rej(parsed);\n                    }\n                    return;\n                }\n\n                res('SUCCESS: Password has been changed.');\n            });\n    });\n}\n\nexport async function updateProfile(form: Form<UserAttributes>): Promise<UserProfile> {\n    await this.__connection;\n    if (!this.session) {\n        throw new SkapiError('User login is required.', { code: 'INVALID_REQUEST' });\n    }\n\n    let params = validator.Params(form || {}, {\n        user_id: (v: string) => validator.UserId(v),\n        email: (v: string) => validator.Email(v),\n        address: (v: any) => {\n            if (!v) return '';\n\n            if (typeof v === 'string') {\n                return v;\n            }\n\n            if (typeof v === 'object') {\n                return JSON.stringify(v);\n            }\n\n            return undefined;\n        },\n        name: 'string',\n        gender: 'string',\n        birthdate: (v: string) => v ? validator.Birthdate(v) : \"\",\n        phone_number: (v: string) => v ? validator.PhoneNumber(v) : \"\",\n        email_public: 'boolean',\n        phone_number_public: 'boolean',\n        address_public: 'boolean',\n        gender_public: 'boolean',\n        birthdate_public: 'boolean',\n        misc: 'string',\n\n        picture: (v: string) => v ? validator.Url(v) : \"\",\n        profile: (v: string) => v ? validator.Url(v) : \"\",\n        family_name: 'string',\n        given_name: 'string',\n        middle_name: 'string',\n        nickname: 'string',\n        website: (v: string) => v ? validator.Url(v) : \"\",\n    });\n\n    if (params && typeof params === 'object' && !Object.keys(params).length) {\n        return this.user;\n    }\n\n    // set alternative signin email\n    if (params.email) {\n        params['preferred_username'] = this.service + '-' + MD5.hash(params.email);\n    }\n\n    let collision = [\n        ['email_public', 'email_verified', \"User's e-mail should be verified to set\"],\n        ['phone_number_public', 'phone_number_verified', \"User's phone number should be verified to set\"]\n    ];\n\n    if (this.__user) {\n        for (let c of collision) {\n            if (params[c[0]] && !this.__user[c[1]]) {\n                throw new SkapiError(`${c[2]} \"${c[0]}\" to true.`, { code: 'INVALID_REQUEST' });\n            }\n        }\n    }\n\n    // delete unchanged values, convert key names to cognito attributes\n    let toRemove = [];\n    for (let k in params) {\n        if (params[k] === this.user[k]) {\n            toRemove.push(k);\n            continue;\n        }\n\n        let customAttr = [\n            'email_public',\n            'phone_number_public',\n            'address_public',\n            'gender_public',\n            'birthdate_public',\n            'misc'\n        ];\n\n        if (customAttr.includes(k)) {\n            let parseValue = params[k];\n\n            if (typeof parseValue === 'boolean') {\n                parseValue = parseValue ? '1' : '0';\n            }\n\n            params['custom:' + k] = parseValue;\n            toRemove.push(k);\n        }\n    }\n\n    for (let k of toRemove) {\n        delete params[k];\n    }\n\n    if (params.user_id) {\n        let user_id = params.user_id;\n        if (user_id === this.user.user_id) {\n            delete params.user_id;\n        }\n        else {\n            return request.bind(this)('admin-edit-profile', { attributes: params }, { auth: true });\n        }\n    }\n\n    if (params && typeof params === 'object' && Object.keys(params).length) {\n        // format params to cognito attribute\n        let toSet: Array<CognitoUserAttribute> = [];\n        for (let key in params) {\n            toSet.push(new CognitoUserAttribute({\n                Name: key,\n                Value: params[key]\n            }));\n        }\n\n        await new Promise((res, rej) => {\n            cognitoUser?.updateAttributes(\n                toSet,\n                (err: any, result: any) => {\n                    if (err) {\n                        rej(\n                            [\n                                err?.code || err?.name,\n                                err?.message || `Failed to update user settings.`\n                            ]\n                        );\n                    }\n                    res(result);\n                });\n        });\n\n        await authentication.bind(this)().getSession({ refreshToken: true });\n        return this.user;\n    }\n\n    return this.user;\n}\n\nexport async function getUsers(\n    params?: {\n        searchFor: string;\n        value: string | number | boolean | string[];\n        condition?: '>' | '>=' | '=' | '<' | '<=' | 'gt' | 'gte' | 'eq' | 'lt' | 'lte';\n        range?: string | number | boolean;\n    },\n    fetchOptions?: FetchOptions): Promise<DatabaseResponse<UserPublic>> {\n\n    params = extractFormData(params).data as any;\n\n    if (!params) {\n        // set default value\n        params = {\n            searchFor: 'timestamp',\n            condition: '>',\n            value: 0\n        };\n\n        if (!fetchOptions) {\n            fetchOptions = {};\n        }\n\n        fetchOptions.ascending = false;\n    }\n\n    await this.__connection;\n\n    const searchForTypes = {\n        'user_id': (v: string) => {\n            if (Array.isArray(v)) {\n                return v.map(id => validator.UserId(id));\n            }\n            return validator.UserId(v)\n        },\n        'email': 'string',\n        'phone_number': 'string',\n        'locale': (v: string) => {\n            if (typeof v !== 'string' || typeof v === 'string' && v.length > 5) {\n                throw new SkapiError('Value of \"locale\" should be a country code.', { code: 'INVALID_PARAMETER' });\n            }\n            return v;\n        },\n        'name': 'string',\n        'address': 'string',\n        'gender': 'string',\n        'birthdate': (v: string) => validator.Birthdate(v),\n        'subscribers': 'number',\n        'timestamp': 'number',\n        'access_group': 'number',\n        'approved': 'string'\n    };\n\n    let required = ['searchFor', 'value'];\n\n    params = validator.Params(params, {\n        searchFor: [\n            'user_id',\n            'name',\n            'email',\n            'phone_number',\n            'address',\n            'gender',\n            'birthdate',\n            'locale',\n            'subscribers',\n            'timestamp',\n            'access_group',\n            'approved'\n        ],\n        condition: ['>', '>=', '=', '<', '<=', 'gt', 'gte', 'eq', 'lt', 'lte', () => '='],\n        value: (v: any) => {\n            let checker = searchForTypes[params.searchFor];\n            if (typeof checker === 'function') {\n                return checker(v);\n            }\n\n            else if (typeof v !== checker) {\n                throw new SkapiError(`Value does not match the type of \"${params.searchFor}\" index.`, { code: 'INVALID_PARAMETER' });\n            }\n\n            return v;\n        },\n        range: (v: any) => {\n            let checker = searchForTypes[params.searchFor];\n            if (typeof checker === 'function') {\n                return checker(v);\n            }\n\n            else if (typeof v !== checker) {\n                throw new SkapiError(`Range does not match the type of \"${params.searchFor}\" index.`, { code: 'INVALID_PARAMETER' });\n            }\n\n            return v;\n        }\n    }, required);\n\n    if (params?.condition && params?.condition !== '=' && params.hasOwnProperty('range')) {\n        throw new SkapiError('Conditions does not apply on range search.', { code: 'INVALID_PARAMETER' });\n    }\n\n    if (params.searchFor === 'user_id' && (params.condition !== '=' || params.range)) {\n        throw new SkapiError(`Conditions are not allowed on \"${params.searchFor}\"`, { code: 'INVALID_PARAMETER' });\n    }\n\n    if (typeof params?.value === 'string' && !params?.value) {\n        throw new SkapiError('Value should not be an empty string.', { code: 'INVALID_PARAMETER' });\n    }\n\n    if (typeof params?.searchFor === 'string' && !params?.searchFor) {\n        throw new SkapiError('\"searchFor\" should not be an empty string.', { code: 'INVALID_PARAMETER' });\n    }\n\n    return request.bind(this)('get-users', params, { auth: true, fetchOptions });\n}\n\n/**\n * Not official. Bleeding edge.<br>\n * Retrieves, reverts e-mail to last verified email.<br>\n * @returns Last verified e-mail address, or updated userProfile when params.revert is true.\n */\nexport async function lastVerifiedEmail(params?: {\n    /** Reverts to last verified e-mail when true. */\n    revert: boolean;\n}): Promise<string | UserProfile> {\n    await this.__connection;\n    let res = await request.bind(this)('last-verified-email', params, { auth: true });\n    if (res.includes('SUCCESS')) {\n        await authentication.bind(this)().getSession({ refreshToken: true });\n        return this.user;\n    }\n    return res;\n}\n\n/**\n * Not official. Bleeding edge.<br>\n * Requests username(e-mail) change.<br>\n * skapi server will send username change confirmation e-mail to user.<br>\n * Username will not be changed when the user did not confirm.<br>\n * Confirmation e-mail is valid within 24 hours.\n */\nexport async function requestUsernameChange(params: {\n    /** Redirect URL when user clicks on the link. */\n    redirect?: string;\n    /** username(e-mail) user wish to change to. */\n    username: string;\n}): Promise<'SUCCESS: confirmation e-mail has been sent.'> {\n    await this.__connection;\n\n    params = validator.Params(params, {\n        username: validator.Email,\n        redirect: validator.Url\n    }, ['username']);\n\n    return await request.bind(this)('request-username-change', params, { auth: true });\n}","\nimport SkapiError from '../main/error';\nimport { Form, FetchOptions, DatabaseResponse, ProgressCallback } from '../Types';\nimport validator from './validator';\nimport { MD5, generateRandom, extractFormData, isBrowserRuntime } from './utils';\n// import { authentication, getJwtToken } from '../methods/user';\nimport { getJwtToken } from '../methods/user';\nimport Qpass from \"qpass\";\n\nlet requestQueue = null;\nconst hasSubmitEvent = typeof SubmitEvent !== 'undefined';\nconst hasHTMLFormElement = typeof HTMLFormElement !== 'undefined';\nconst isBrowser = isBrowserRuntime();\n// Global counters for round-robin\nlet request_counter = 0;\n\nfunction getRetryDelayMs(retryAfter: string | null): number | null {\n    if (!retryAfter) {\n        return null;\n    }\n\n    const seconds = Number(retryAfter);\n    if (Number.isFinite(seconds)) {\n        return Math.max(0, seconds * 1000);\n    }\n\n    const dateMs = Date.parse(retryAfter);\n    if (!Number.isNaN(dateMs)) {\n        return Math.max(0, dateMs - Date.now());\n    }\n\n    return null;\n}\n\nfunction toPercent(loaded: number, total: number): number {\n    return total > 0 ? (loaded / total) * 100 : 0;\n}\n\nlet selectGateway = (params: { auth: boolean, type: string, endpoints: {[key:string]: string}[] }) => {\n    const { auth, type, endpoints } = params;\n\n    const admin = endpoints[0];\n    // {\n    //     \"admin_public\": \"https://nty2bxrol1.execute-api.eu-west-1.amazonaws.com/api/\",\n    //     \"admin_private\": \"https://4250a1g3bd.execute-api.eu-west-1.amazonaws.com/api/\",\n    //     \"admin_public_2\": \"https://of8ur90ix1.execute-api.eu-west-1.amazonaws.com/api/\",\n    //     \"admin_private_2\": \"https://gge4qiyqv2.execute-api.eu-west-1.amazonaws.com/api/\",\n    //     \"get_users_private\": \"https://eztrfvyq49.execute-api.eu-west-1.amazonaws.com/api/\",\n    //     \"service_public\": \"https://pg695jr002.execute-api.eu-west-1.amazonaws.com/api/\",\n    //     \"extra_public\": \"https://8zpb401kr3.execute-api.eu-west-1.amazonaws.com/api/\",\n    //     \"extra_private\": \"https://o5vqmktoa4.execute-api.eu-west-1.amazonaws.com/api/\",\n    //     \"extra_public_2\": \"https://u3c0pt5v7a.execute-api.eu-west-1.amazonaws.com/api/\",\n    //     \"extra_private_2\": \"https://dr6glk4kz8.execute-api.eu-west-1.amazonaws.com/api/\",\n    //     \"userpool_id\": \"eu-west-1_vq4rt05un\",\n    //     \"userpool_client\": \"76uku0vqmkko2os1s8sh8dmpar\"\n    // }\n    const record = endpoints[1];\n    // {\n    //     \"record_public\": \"https://9zxjxkrczi.execute-api.ap-northeast-1.amazonaws.com/api/\",\n    //     \"record_private\": \"https://luvgxcgpwd.execute-api.ap-northeast-1.amazonaws.com/api/\",\n    //     \"record_public_2\": \"https://ekhpyuchg6.execute-api.ap-northeast-1.amazonaws.com/api/\",\n    //     \"record_private_2\": \"https://nprhgj1xkj.execute-api.ap-northeast-1.amazonaws.com/api/\",\n    //     \"post_public\": \"https://cbzajunw33.execute-api.ap-northeast-1.amazonaws.com/api/\",\n    //     \"post_private\": \"https://j51bbrnqb7.execute-api.ap-northeast-1.amazonaws.com/api/\",\n    //     \"get_public\": \"https://nmnczc41wg.execute-api.ap-northeast-1.amazonaws.com/api/\",\n    //     \"get_private\": \"https://0zpwltd5yh.execute-api.ap-northeast-1.amazonaws.com/api/\",\n    //     \"del_private\": \"https://w7grra2h6k.execute-api.ap-northeast-1.amazonaws.com/api/\",\n    //     \"websocket_private\": \"wss://t47k8wdn19.execute-api.ap-northeast-1.amazonaws.com/api\"\n    // }\n\n    request_counter++;\n\n    if (type === 'admin') {\n        const gateways_admin_round_robin = Object.entries(admin)\n            .filter(([k, v]) => k.includes(auth ? '_private' : '_public') && k !== 'get_users_private' && k !== 'service_public' && typeof v === 'string')\n            .map(([, v]) => v);\n\n        if (!gateways_admin_round_robin.length) {\n            throw new SkapiError('No available admin gateways.', { code: 'INVALID_REQUEST' });\n        }\n\n        return gateways_admin_round_robin[request_counter % gateways_admin_round_robin.length];\n    }\n    if (type === 'record') {\n        const gateways_record_round_robin = Object.entries(record)\n            .filter(([k, v]) => k.includes(auth ? 'record_private' : 'record_public') && typeof v === 'string')\n            .map(([, v]) => v);\n\n        if (!gateways_record_round_robin.length) {\n            throw new SkapiError('No available record gateways.', { code: 'INVALID_REQUEST' });\n        }\n\n        return gateways_record_round_robin[request_counter % gateways_record_round_robin.length];\n    }\n\n    throw new SkapiError('Invalid gateway type.', { code: 'INVALID_REQUEST' });\n}\n\nasync function getEndpoint(dest: string, auth: boolean) {\n    const endpoints = await Promise.all([\n        this.admin_endpoint,\n        this.record_endpoint\n    ]);\n\n    const admin = endpoints[0];\n    const record = endpoints[1];\n\n    let params = dest.split('?');\n    let query = params.length > 1 ? '?' + params[1] : '';\n    dest = params[0];\n\n    switch (dest) {\n        case 'get-users': ////\n            return admin.get_users_private + dest + query;\n        case 'service': ////\n            return admin.service_public + dest + query;\n        case 'get-newsletters':\n        case 'get-public-newsletters':\n        case 'subscribe-newsletter':\n        case 'subscribe-public-newsletter':\n        case 'signupkey':\n        case 'admin-newsletter-request':\n        case 'admin-signup':\n        case 'confirm-signup':\n        case 'openid-logger':\n        case 'block-account':\n        case 'admin-edit-profile':\n        case 'remove-account':\n        case 'post-secure':\n        case 'recover-account':\n        case 'mock':\n        case 'grant-access':\n        case 'last-verified-email':\n        case 'ticket':\n        case 'register-ticket':\n        case 'get-newsletter-subscription':\n        case 'request-username-change':\n        case 'send-inquiry':\n        case 'register-newsletter-group':\n        case 'newsletter-group-endpoint':\n        case 'invitation-list':\n        case 'csr':\n            return selectGateway.bind(this)({ auth, type: 'admin', endpoints }) + dest + query;\n\n        // Records\n        case 'post-record': ////\n            // Dedicated gateway api for post-record\n            return (auth ? record.post_private : record.post_public) + dest + query;\n\n        case 'get-records': ////\n            // Dedicated gateway api for get-record\n            return (auth ? record.get_private : record.get_public) + dest + query;\n\n        case 'del-files': //\n        case 'del-records': //\n            // Dedicated gateway api for del-records and del-files\n            return record.del_private + dest + query;\n        case 'store-subscription':\n        case 'get-vapid-public-key':\n        case 'push-notification':\n        case 'delete-subscription':\n        case 'subscription':\n        case 'get-subscription':\n        case 'get-table':\n        case 'get-tag':\n        case 'get-uniqueid':\n        case 'get-index':\n        case 'get-signed-url':\n        case 'grant-private-access':\n        case 'request-private-access-key':\n        case 'get-ws-group':\n        case 'check-schema':\n        case 'get-feed':\n        // From viviplayground\n        case 'castspell':\n        case 'dopamine':\n        case 'getspell':\n            return selectGateway.bind(this)({ auth, type: 'record', endpoints }) + dest + query;\n\n        default:\n            return validator.Url(dest) + query;\n    }\n}\n\nconst __pendingRequest: Record<string, Promise<any>> = {};\n\nexport function terminatePendingRequests() {\n    if (requestQueue) {\n        requestQueue.terminate();\n        requestQueue = null;\n    }\n}\n\nexport async function request(\n    url: string,\n    data: Form<any> = null,\n    options?: {\n        fetchOptions?: FetchOptions;\n        auth?: boolean;\n        method?: string;\n        bypassAwaitConnection?: boolean;\n        responseType?: 'json' | 'blob' | 'text' | 'arrayBuffer' | 'formData' | 'document';\n        contentType?: string;\n    },\n    _etc?: {\n        ignoreService: boolean;\n    }\n): Promise<any> {\n    this.log('request', { url, data, options, _etc: _etc || {} });\n\n    options = options || {};\n\n    let {\n        auth = false,\n        method = 'post',\n        bypassAwaitConnection = false,\n    } = options;\n\n    method = method.toUpperCase();\n\n    let __connection = null;\n    let service = data?.service || this.service;\n    let owner = data?.owner || this.owner;\n    let token = null; // idToken\n    let endpoint = await getEndpoint.bind(this)(url, !!auth);\n\n    if (!bypassAwaitConnection) {\n        __connection = await this.__connection;\n        if (!__connection) {\n            throw new SkapiError('Invalid connection. The service could have been disabled, or has a restricted CORS.', { code: 'INVALID_REQUEST' });\n        }\n    }\n\n    if (auth) {\n        token = await getJwtToken.bind(this)();\n    }\n\n    let fetchOptions = {}; // record fetch options\n    let { fetchMore = false, progress } = options?.fetchOptions || {};\n\n    if (options?.fetchOptions && Object.keys(options.fetchOptions).length) {\n        for (let k of ['limit', 'startKey', 'ascending']) {\n            if (options.fetchOptions.hasOwnProperty(k)) {\n                fetchOptions[k] = options.fetchOptions[k];\n            }\n        }\n\n        fetchOptions = validator.Params(\n            fetchOptions,\n            {\n                limit: v => {\n                    if (typeof v !== 'number') {\n                        throw new SkapiError('Fetch limit should be a number.', { code: 'INVALID_REQUEST' });\n                    }\n                    if (v > 1000) {\n                        throw new SkapiError('Fetch limit should be below 1000.', { code: 'INVALID_REQUEST' });\n                    }\n                    return v;\n                },\n                startKey: v => v,\n                ascending: 'boolean'\n            }\n        );\n    }\n\n    let required = _etc?.ignoreService ? {} : { service, owner };\n    Object.assign(required, fetchOptions);\n\n    data = extractFormData(data).data;\n\n    if (!data) {\n        // set data to required parameter\n        data = required;\n    }\n    else if (data && typeof data === 'object') {\n        // add required to data\n        data = Object.assign(required, data);\n    }\n\n    let requestFingerprint = `${method}:${auth ? 'auth' : 'public'}:${url}`;\n\n    let hashedParams = (() => {\n        if (data && typeof data === 'object' && Object.keys(data).length && !(isBrowser && data instanceof FormData)) {\n            // hash request parameters\n            function sortObject(obj: Record<string, any>): Record<string, any> {\n                if (typeof obj === 'object' && obj !== null) {\n                    return Object.keys(obj)\n                        .sort()\n                        .reduce((res, key) => {\n                            if (typeof obj[key] === 'object' && obj[key] !== null) {\n                                // If the value is an object, sort it recursively\n                                res[key] = sortObject(obj[key]);\n                            } else {\n                                res[key] = obj[key];\n                            }\n                            return res;\n                        }, {});\n                }\n                return obj;\n            };\n\n            return MD5.hash(requestFingerprint + '/' + JSON.stringify(sortObject(data)));\n        }\n\n        return MD5.hash(requestFingerprint + '/' + service);\n    })();\n\n    let { requestKey, requestKeyWithStartKey } = load_startKey_keys.bind(this)({\n        params: data,\n        url,\n        fetchMore,\n        hashedParams\n    }); // returns requrestKey | cached data\n\n    if (!requestKey || requestKey && typeof requestKey === 'object') {\n        // cached data can be falsy data or object\n        return requestKey;\n    }\n\n    this.log('requestKey', requestKeyWithStartKey);\n\n    // prevent duplicate request\n    if (typeof requestKeyWithStartKey === 'string' && __pendingRequest[requestKeyWithStartKey] instanceof Promise) {\n        this.log('request:returning pending', requestKeyWithStartKey);\n        return __pendingRequest[requestKeyWithStartKey as string];\n    }\n\n    // new request\n    let headers: Record<string, any> = {\n        'Accept': '*/*'\n    };\n\n    const hasCustomContentType = Object.prototype.hasOwnProperty.call(options, 'contentType') && options.contentType !== undefined;\n    if (hasCustomContentType) {\n        const configuredContentType = options.contentType === null ? 'application/x-www-form-urlencoded' : options.contentType;\n        if (configuredContentType) {\n            headers['Content-Type'] = configuredContentType;\n        }\n    }\n    else if (isBrowser && !(data instanceof FormData)) {\n        headers['Content-Type'] = 'application/json';\n    }\n    else {\n        headers['Content-Type'] = 'application/json';\n    }\n\n    if (token) {\n        headers.Authorization = token;\n    }\n\n    let meta = {\n        public_identifier: this.__public_identifier,\n        service,\n        owner\n    };\n\n    headers['Content-Meta'] = JSON.stringify(meta);\n\n    // if (headers['Content-Type'] !== 'application/json') {\n    //     // add service and owner to headers if content type is not json\n    //     headers['Content-Meta'] = JSON.stringify(meta);\n    // }\n\n    let opt: RequestInit & { responseType?: string | null, headers: Record<string, any>; } = { headers }; // request options\n    if (options?.responseType) {\n        opt.responseType = options.responseType;\n    }\n\n    if (method === 'GET') {\n        if (data) {\n            let query = [];\n            if (isBrowser && data instanceof FormData) {\n                query = Array.from(data.entries()).map(([k, value]) => {\n                    const stringValue = typeof value === 'string' ? value : value.name;\n                    return encodeURIComponent(k) + '=' + encodeURIComponent(stringValue);\n                });\n            }\n            else {\n                query = Object.keys(data)\n                    .map(k => {\n                        let value = data[k];\n                        if (typeof value !== 'string') {\n                            value = JSON.stringify(value);\n                        }\n                        return encodeURIComponent(k) + '=' + encodeURIComponent(value);\n                    });\n            }\n\n            if (query.length) {\n                const separator = endpoint.includes('?')\n                    ? (endpoint.endsWith('?') || endpoint.endsWith('&') ? '' : '&')\n                    : '?';\n                endpoint += separator + query.join('&');\n            }\n        }\n        opt.body = null;\n    }\n    else {\n        if (isBrowser && data instanceof FormData) {\n            opt.body = data;\n        }\n        else if (headers['Content-Type'] === 'application/x-www-form-urlencoded' && data && typeof data === 'object') {\n            const encoded = new URLSearchParams();\n            for (let key of Object.keys(data)) {\n                const value = data[key];\n                encoded.append(key, typeof value === 'string' ? value : JSON.stringify(value));\n            }\n            opt.body = encoded.toString();\n        }\n        else if (typeof data === 'string') {\n            opt.body = data;\n        }\n        else {\n            opt.body = data ? JSON.stringify(data) : null;\n        }\n    }\n\n    opt.method = method;\n\n    if (requestQueue === null) {\n        let config = {\n            batchSize: this.requestBatchSize,\n            breakWhenError: false,\n            onProgress: (progress) => {\n                // for(let key in __pendingRequest) {\n                //     delete __pendingRequest[key];\n                // }\n                this.onBatchProcess.forEach((cb) => cb(progress));\n            }\n        };\n\n        requestQueue = new Qpass(config);\n    }\n\n    this.log('request-opt', opt);\n\n    return new Promise((res, rej) => {\n        requestQueue.add([async () => {\n            let promise = _fetch.bind(this)(endpoint, opt, progress);\n            __pendingRequest[requestKeyWithStartKey as string] = promise;\n\n            try {\n                let result = update_startKey_keys.bind(this)({\n                    hashedParam: requestKey,\n                    requestKeyWithStartKey,\n                    url,\n                    fetched: await promise\n                });\n                delete __pendingRequest[requestKeyWithStartKey];\n                this.log('request:end', result);\n                res(result);\n                return result;\n            }\n            catch (err) {\n                delete __pendingRequest[requestKeyWithStartKey];\n                this.log('request:err', err);\n                rej(err);\n                throw err;\n            }\n        }]);\n    });\n}\n\nfunction load_startKey_keys(option: {\n    params: Record<string, any>;\n    url: string;\n    fetchMore: boolean;\n    hashedParams: string;\n}): { requestKeyWithStartKey: string, requestKey: string | DatabaseResponse<any> } {\n    let { params = {}, url, fetchMore = false, hashedParams } = option || {};\n\n    if (params.startKey) {\n        if (\n            !(typeof params.startKey === 'object' && Object.keys(params.startKey).length) &&\n            params.startKey !== 'start' && params.startKey !== 'end'\n        ) {\n            throw new SkapiError(`\"${params.startKey}\" is invalid startKey key.`, { code: 'INVALID_PARAMETER' });\n        }\n\n        if (params.startKey === 'start') {\n            // deletes referenced object key\n            fetchMore = false;\n            delete params.startKey;\n        }\n    }\n\n    if (!fetchMore) {\n        // init cache, init startKey\n\n        if (this.__cached_requests?.[url]?.[hashedParams]) {\n            // delete cached data start\n            delete this.__cached_requests[url][hashedParams];\n        }\n\n        if (this.__startKeyHistory?.[url]?.[hashedParams]) {\n            if (Array.isArray(this.__startKeyHistory[url][hashedParams]) && this.__startKeyHistory[url][hashedParams].length) {\n                // delete cache of all startkeys\n                for (let p of this.__startKeyHistory[url][hashedParams]) {\n                    let hashedParams_cached = hashedParams + MD5.hash(p);\n                    if (this.__cached_requests?.[url] && this.__cached_requests?.[url]?.[hashedParams_cached]) {\n                        delete this.__cached_requests[url][hashedParams_cached];\n                    }\n                }\n            }\n\n            // delete start key lists\n            delete this.__startKeyHistory[url][hashedParams];\n        }\n\n        return { requestKeyWithStartKey: hashedParams, requestKey: hashedParams };\n    }\n\n    if (!Array.isArray(this.__startKeyHistory?.[url]?.[hashedParams])) {\n        // startkey does not exists\n        return { requestKeyWithStartKey: hashedParams, requestKey: hashedParams };\n    }\n\n    // hashed params exists\n    let list_of_startKeys = this.__startKeyHistory[url][hashedParams]; // [\"{<startKey key>}\", ...'end']\n    let last_startKey_key = list_of_startKeys[list_of_startKeys.length - 1];\n    let requestKeyWithStartKey = hashedParams;\n\n    if (last_startKey_key) {\n        // use last start key\n        // requestKeyWithStartKey += MD5.hash(last_startKey_key);\n\n        if (last_startKey_key === 'end') { // cached startKeys are stringified\n            return {\n                requestKey: {\n                    list: [],\n                    startKey: 'end',\n                    endOfList: true,\n                    startKeyHistory: list_of_startKeys\n                },\n                requestKeyWithStartKey\n            }\n        }\n\n        // else {\n        requestKeyWithStartKey += MD5.hash(last_startKey_key);\n        params.startKey = JSON.parse(last_startKey_key);\n        // }\n    }\n\n    if (this.__cached_requests?.[url]?.[requestKeyWithStartKey]) {\n        // return data if there is cache\n        return { requestKey: this.__cached_requests[url][requestKeyWithStartKey], requestKeyWithStartKey };\n    }\n\n    // return hashedParams;\n    return { requestKeyWithStartKey, requestKey: hashedParams };\n}\n\nfunction _fetch(url: string, opt: any, progress?: ProgressCallback) {\n    return new Promise(\n        (res, rej) => {\n            let xhr = new XMLHttpRequest();\n\n            // 0: UNSENT - The request is not initialized.\n            // 1: OPENED - The request has been set up.\n            // 2: HEADERS_RECEIVED - The request has sent, and the headers and status are available.\n            // 3: LOADING - The response's body is being received.\n            // 4: DONE - The data transfer has been completed or an error has occurred during the \n\n            // xhr.onreadystatechange = function () {\n            //     if (xhr.readyState === 4) {   //if complete\n            //         if (xhr.status >= 200 || xhr.status <= 299) {  //check if \"OK\" (200)\n            //             //success\n            //         } else {\n            //             rej(xhr.status); //otherwise, some other code was returned\n            //         }\n            //     }\n            // };\n\n            xhr.open(opt.method || 'GET', url);\n\n            for (var k in opt.headers || {}) {\n                xhr.setRequestHeader(k, opt.headers[k]);\n            }\n\n            if (opt.responseType) {\n                xhr.responseType = opt.responseType;\n            }\n\n            xhr.onload = () => {\n                if (xhr.status < 400) {\n                    // Status codes in the 2xx range mean success\n                    if (opt.responseType == 'json' || opt.responseType == 'blob') {\n                        res(xhr.response);\n                    }\n                    else {\n                        let result = xhr.responseText;\n                        try {\n                            result = JSON.parse(result);\n                        }\n                        catch (err) { }\n                        res(result);\n                    }\n                }\n\n                else if (xhr.status === 429) {\n                    // too many requests\n                    let retryAfter = xhr.getResponseHeader('Retry-After');\n                    let retryDelayMs = getRetryDelayMs(retryAfter);\n                    if (retryDelayMs !== null) {\n                        setTimeout(() => {\n                            _fetch(url, opt, progress).then(res, rej);\n                        }, retryDelayMs);\n                    }\n                    else {\n                        rej('Too many requests');\n                    }\n                }\n\n                else {\n                    // Status codes outside the 2xx range indicate errors\n                    let status = xhr.status;\n                    let errCode = [\n                        'INVALID_CORS',\n                        'INVALID_REQUEST',\n                        'SERVICE_DISABLED',\n                        'INVALID_PARAMETER',\n                        'ERROR',\n                        'EXISTS',\n                        'NOT_EXISTS'\n                    ];\n\n                    let result: any = opt.responseType == 'blob' ? xhr.response : xhr.responseText;\n                    try {\n                        result = JSON.parse(result);\n                    }\n                    catch (err) { }\n                        \n                    if (typeof result === 'string') {\n                        let errMsg = result.split(':');\n                        let code = errMsg.splice(0, 1)[0].trim();\n                        let msg = errMsg.join(':').trim();\n                        rej(new SkapiError(msg || result, { code: (errCode.includes(code) ? code : 'ERROR') }));\n                    }\n\n                    else if (typeof result === 'object' && result?.message) {\n                        let code = (result?.code || (status ? status.toString() : null) || 'ERROR');\n                        let message = result.message;\n                        let cause = result?.cause;\n                        if (typeof message === 'string') {\n                            message = message.trim();\n                        }\n                        rej(new SkapiError(message, { cause, code }));\n                    }\n\n                    else {\n                        rej(result);\n                    }\n                }\n            };\n\n            xhr.onerror = () => rej('Network error');\n            xhr.onabort = () => rej('Aborted');\n            xhr.ontimeout = () => rej('Timeout');\n\n            if (typeof progress === 'function') {\n                xhr.onprogress = (p: ProgressEvent) => {\n                    progress(\n                        {\n                            status: 'download',\n                            progress: toPercent(p.loaded, p.total),\n                            loaded: p.loaded,\n                            total: p.total,\n                            abort: () => xhr.abort()\n                        }\n                    );\n                };\n                if (xhr.upload) {\n                    xhr.upload.onprogress = (p: ProgressEvent) => {\n                        progress(\n                            {\n                                status: 'upload',\n                                progress: toPercent(p.loaded, p.total),\n                                loaded: p.loaded,\n                                total: p.total,\n                                abort: () => xhr.abort()\n                            }\n                        );\n                    };\n                }\n            }\n\n            xhr.send(opt.body);\n        }\n    );\n}\n\nfunction update_startKey_keys(option: Record<string, any>) {\n    let { hashedParam, requestKeyWithStartKey, url, fetched } = option;\n\n    if (!fetched?.startKey) {\n        // no startkey no caching\n        return fetched;\n    }\n\n    // has start key\n    // startkey is key for next fetch\n\n    // this.__startKeyHistory[url] = {\n    //     [hashedParam]: ['{<startKey key>}', ...'end'],\n    //     ...\n    // }\n\n    // this.__cached_requests[url][hashsedParams + md5(JSON.stringify(startKey))] = {\n    //     data\n    //     ...\n    // }\n\n    if (!this.__startKeyHistory.hasOwnProperty(url)) {\n        // create url key to store startKey key list if it doesnt exists\n        this.__startKeyHistory[url] = {};\n    }\n\n    if (!this.__startKeyHistory[url].hasOwnProperty(hashedParam)) {\n        this.__startKeyHistory[url][hashedParam] = [];\n    }\n\n    let startKey_string = fetched.startKey === 'end' ? 'end' : JSON.stringify(fetched.startKey);\n    if (!this.__startKeyHistory[url][hashedParam].includes(startKey_string)) {\n        this.__startKeyHistory[url][hashedParam].push(startKey_string);\n    }\n\n    // let hashedParamWithStartKey = hashedParam + MD5.hash(startKey_string);\n\n    if (!this.__cached_requests?.[url]) {\n        this.__cached_requests[url] = {};\n    }\n    // this.__cached_requests[url][hashedParamWithStartKey] = fetched;\n    this.__cached_requests[url][requestKeyWithStartKey] = fetched;\n\n    return Object.assign({ startKeyHistory: this.__startKeyHistory[url][hashedParam] }, fetched);\n}\n\nexport async function uploadFiles(\n    fileList: FormData | HTMLFormElement | SubmitEvent,\n    params: {\n        record_id: string; // Record ID of a record to upload files to.\n        progress?: ProgressCallback;\n    }\n): Promise<{ completed: File[]; failed: File[]; bin_endpoints: string[] }> {\n    await this.__connection;\n    let { record_id, service = this.service, progress } = (params as { [key: string]: any })\n\n    if (!record_id) {\n        throw new SkapiError('\"record_id\" is required.', { code: 'INVALID_PARAMETER' });\n    }\n\n    if (hasSubmitEvent && fileList instanceof SubmitEvent) {\n        fileList = (fileList.target as HTMLFormElement);\n    }\n\n    if (hasHTMLFormElement && fileList instanceof HTMLFormElement) {\n        fileList = new FormData(fileList);\n    }\n\n    if (!isBrowser || !(fileList instanceof FormData)) {\n        throw new SkapiError('\"fileList\" should be a FormData or HTMLFormElement.', { code: 'INVALID_PARAMETER' });\n    }\n\n    let reserved_key = generateRandom();\n\n    let getSignedParams: Record<string, any> = {\n        reserved_key,\n        service,\n        request: 'post'\n    };\n\n    if (params?.record_id) {\n        getSignedParams.id = params.record_id;\n    }\n\n    let xhr;\n\n    let fetchProgress = (\n        url: string,\n        body: FormData,\n        progressCallback: (p: ProgressEvent) => void\n    ) => {\n        return new Promise((res, rej) => {\n            xhr = new XMLHttpRequest();\n            xhr.open('POST', url);\n            xhr.onload = () => {\n                let result = xhr.responseText;\n                try {\n                    result = JSON.parse(result);\n                }\n                catch (err) { }\n                if (xhr.status >= 200 && xhr.status < 300) {\n                    res(result);\n                }\n                else if (xhr.status === 429) {\n                    // too many requests\n                    let retryAfter = xhr.getResponseHeader('Retry-After');\n                    let retryDelayMs = getRetryDelayMs(retryAfter);\n                    if (retryDelayMs !== null) {\n                        setTimeout(() => {\n                            fetchProgress(url, body, progressCallback).then(res, rej);\n                        }, retryDelayMs);\n                    }\n                    else {\n                        rej('Too many requests');\n                    }\n                }\n                else {\n                    rej(result);\n                }\n            };\n            xhr.onerror = () => rej('Network error');\n            xhr.onabort = () => rej('Aborted');\n            xhr.ontimeout = () => rej('Timeout');\n\n            // xhr.addEventListener('error', rej);\n            if (xhr.upload && typeof progressCallback === 'function') {\n                xhr.upload.onprogress = progressCallback;\n            }\n\n            xhr.send(body);\n        });\n    };\n\n    function toBase62(num: number) {\n        const base62Chars = \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz\";\n        if (num === 0) return base62Chars[0];\n        let result = '';\n        while (num > 0) {\n            result = base62Chars[num % 62] + result;\n            num = Math.floor(num / 62);\n        }\n        return result;\n    }\n\n    let completed = [];\n    let failed = [];\n    let bin_endpoints = [];\n\n    for (let [key, f] of (fileList as any).entries()) {\n        if (!(f instanceof File)) {\n            continue;\n        }\n\n        let signedParams = Object.assign({\n            key: key + '/' + f.name,\n            sizeKey: toBase62(f.size),\n            contentType: f.type || null\n        }, getSignedParams);\n\n        let { fields = null, url, cdn } = await request.bind(this)('get-signed-url', signedParams, { auth: !!this.__user });\n        bin_endpoints.push(cdn);\n        \n        let form = new FormData();\n        for (let name in fields) {\n            form.append(name, fields[name]);\n        }\n\n        form.append('file', f);\n\n        try {\n            await fetchProgress(\n                url,\n                form,\n                typeof progress === 'function' ? (p: ProgressEvent) => progress(\n                    {\n                        status: 'upload',\n                        progress: toPercent(p.loaded, p.total),\n                        currentFile: f,\n                        completed,\n                        failed,\n                        loaded: p.loaded,\n                        total: p.total,\n                        abort: () => xhr.abort()\n                    }\n                ) : null\n            );\n            completed.push(f);\n        } catch (err) {\n            failed.push(f);\n        }\n    }\n\n    return { completed, failed, bin_endpoints };\n}\n\nconst pendPromise: Record<string, Promise<any> | null> = {};\n\nexport function formHandler(options?: { preventMultipleCalls: boolean; }) {\n    let { preventMultipleCalls = false } = options || {};\n\n    // wraps methods that requires form handling\n    return function (target: object, propertyKey: string, descriptor: any) {\n        const fn = descriptor.value;\n\n        descriptor.value = function (...arg: any[]) {\n            let form: Form<any> = arg[0];\n            let storeResponseKey = true;\n            let formEl = null;\n            let actionDestination = '';\n            let fileBase64String = {};\n            let refreshPage = false;\n            if (hasSubmitEvent && form instanceof SubmitEvent) {\n                form.preventDefault();\n\n                let currentUrl = window.location.href;\n                formEl = form.target as HTMLFormElement;\n                let href = new URL(formEl.action);\n                actionDestination = href.href;\n\n                // find {placeholder} in actionDestination url string and replace it with form data value\n                // can be also used as image previewer\n                let placeholders = actionDestination ? actionDestination.match(/(?<=\\{).*?(?=\\})/g) : '';\n                if (placeholders) {\n                    for (let p of placeholders) {\n                        if (!p) {\n                            continue;\n                        }\n\n                        let inputElement = formEl.querySelector(`[name=\"${p}\"]`);\n\n                        // check if input element exists\n                        if (!inputElement) {\n                            continue;\n                        }\n\n                        // check if input element is a file input\n                        if (inputElement.type === 'file') {\n                            for (let i = 0; i <= inputElement.files.length - 1; i++) {\n                                if (!inputElement.files[i])\n                                    continue;\n\n                                if (!fileBase64String[p]) {\n                                    fileBase64String[p] = [];\n                                }\n\n                                fileBase64String[p].push(new Promise((res, rej) => {\n                                    let reader = new FileReader();\n                                    reader.onload = function () {\n                                        res(reader.result);\n                                    };\n                                    reader.readAsDataURL(inputElement.files[i]);\n                                    reader.onerror = rej;\n                                }));\n                            }\n                        }\n                        else {\n                            actionDestination = actionDestination.replace(`{${p}}`, inputElement.value);\n                        }\n                    }\n                }\n\n                if (formEl.getAttribute('action') === null) {\n                    storeResponseKey = false;\n                }\n                else {\n                    refreshPage = href.href === currentUrl;\n                }\n            }\n\n            const handleResponse = async (response: any) => {\n                if (actionDestination) {\n                    for (let k in fileBase64String) {\n                        if (fileBase64String[k].length) {\n                            actionDestination = actionDestination.replace(`{${k}}`, (await Promise.all(fileBase64String[k])).join(','));\n                        }\n                    }\n                }\n\n                if (formEl) {\n                    if (storeResponseKey) {\n                        window.sessionStorage.setItem(`${this.service}:${MD5.hash(actionDestination)}`, JSON.stringify(response));\n                        if (refreshPage) {\n                            window.location.replace(actionDestination);\n                        }\n                        else {\n                            window.location.href = actionDestination;\n                        }\n                    }\n                }\n\n                return response;\n            };\n\n            let response: any;\n            let handleError = (err: any) => {\n                if (err instanceof SkapiError) {\n                    err.name = propertyKey + '()';\n                }\n\n                else {\n                    err = err instanceof Error ? err : new SkapiError(err, { name: propertyKey + '()' });\n                }\n\n                throw err;\n            };\n\n            const executeMethod = async () => {\n                try {\n                    // execute\n                    response = fn.bind(this)(...arg);\n\n                    if (response instanceof Promise) {\n                        // handle promise\n                        let resolved = await response;\n                        return handleResponse(resolved);\n                    }\n\n                    return handleResponse(response);\n                }\n                catch (err) {\n                    throw handleError(err);\n                }\n            };\n\n            if (preventMultipleCalls) {\n                let pendingKey = `${propertyKey}:${this?.__public_identifier || ''}:${this?.service || ''}:${this?.owner || ''}`;\n\n                if (!pendPromise?.[pendingKey]) {\n                    pendPromise[pendingKey] = executeMethod().finally(() => {\n                        delete pendPromise[pendingKey];\n                    });\n                }\n\n                return pendPromise[pendingKey];\n            }\n\n            return executeMethod();\n        }\n    }\n}\n\nexport async function getFormResponse(): Promise<any> {\n    await this.__connection;\n    let responseKey = `${this.service}:${MD5.hash(window.location.href.split('?')[0])}`;\n    let stored = window.sessionStorage.getItem(responseKey);\n    window.sessionStorage.removeItem(responseKey);\n\n    if (stored !== null) {\n        try {\n            stored = JSON.parse(stored);\n        } catch (err) { }\n\n        return stored;\n    }\n\n    return null;\n};","import validator from '../utils/validator';\nimport { SkapiError } from '../Main';\n\nconst MAX_TABLE_NAME_LENGTH = 128;\nconst MAX_TAG_LENGTH = 64;\nconst MAX_INDEX_NAME_LENGTH = 128;\nconst MAX_INDEX_STRING_VALUE_LENGTH = 256;\nconst SENTINEL_CHAR = '\\u{10FFFF}';\nconst CONTROL_OR_SENTINEL_REGEX = /[\\u0000-\\u001F\\u007F]|\\u{10FFFF}/u;\nconst BLOCKED_KEY_SEGMENT_DELIMITER_REGEX = /[\\/!*#]/;\n\nexport function validateStringByPolicy(\n    value: any,\n    fieldName: string,\n    options: {\n        onlyAlphanumeric?: boolean;\n        allowEmpty?: boolean;\n        maxLength?: number;\n        blockKeyDelimiters?: boolean;\n        disallowLeadingDollar?: boolean;\n    } = {}\n) {\n    const {\n        allowEmpty = false,\n        maxLength,\n        blockKeyDelimiters = false,\n        disallowLeadingDollar = false,\n        onlyAlphanumeric = false\n    } = options;\n\n    if (typeof value !== 'string') {\n        throw new SkapiError(`\"${fieldName}\" should be type: <string>.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    if (onlyAlphanumeric && /[^a-zA-Z0-9]/.test(value)) {\n        throw new SkapiError(`\"${fieldName}\" should only contain alphanumeric characters.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    if (!allowEmpty && value.length === 0) {\n        throw new SkapiError(`\"${fieldName}\" is required.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    if (maxLength && value.length > maxLength) {\n        throw new SkapiError(`\"${fieldName}\" should be <= ${maxLength} characters.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    if (CONTROL_OR_SENTINEL_REGEX.test(value) || value.includes(SENTINEL_CHAR)) {\n        throw new SkapiError(`\"${fieldName}\" cannot include control characters or unsupported sentinel characters.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    if (blockKeyDelimiters && BLOCKED_KEY_SEGMENT_DELIMITER_REGEX.test(value)) {\n        throw new SkapiError(`\"${fieldName}\" cannot include reserved delimiters: / ! * #`, { code: 'INVALID_PARAMETER' });\n    }\n\n    if (disallowLeadingDollar && value.startsWith('$')) {\n        throw new SkapiError(`\"${fieldName}\" cannot start with \"$\".`, { code: 'INVALID_PARAMETER' });\n    }\n\n    return value;\n}\n\nexport function validateTableName(value: any, fieldName = 'table.name') {\n    return validateStringByPolicy(value, fieldName, {\n        allowEmpty: false,\n        maxLength: MAX_TABLE_NAME_LENGTH,\n        blockKeyDelimiters: true,\n    });\n}\n\nexport function validateTag(value: any, fieldName = 'tag') {\n    return validateStringByPolicy(value, fieldName, {\n        allowEmpty: false,\n        maxLength: MAX_TAG_LENGTH,\n        blockKeyDelimiters: true,\n    });\n}\n\nexport function validateCustomIndexName(value: any, fieldName = 'index.name') {\n    return validateStringByPolicy(value, fieldName, {\n        allowEmpty: false,\n        maxLength: MAX_INDEX_NAME_LENGTH,\n        blockKeyDelimiters: true,\n        disallowLeadingDollar: true,\n    });\n}\n\nexport function validateIndexStringValue(value: any, fieldName = 'index.value') {\n    return validateStringByPolicy(value, fieldName, {\n        allowEmpty: true,\n        maxLength: MAX_INDEX_STRING_VALUE_LENGTH,\n    });\n}\n\nexport function recordIdOrUniqueId(query) {\n    if (!query.record_id && !query.unique_id) {\n        return null;\n    }\n\n    let outputObj: any = {};\n    if (query?.service) {\n        outputObj.service = query.service;\n    }\n    if (query?.owner) {\n        outputObj.owner = query.owner;\n    }\n    if (query?.record_id) {\n        outputObj.record_id = validateStringByPolicy(query.record_id, 'record_id', {\n            allowEmpty: false,\n            onlyAlphanumeric: true,\n        });\n    }\n    else if (query?.unique_id) {\n        outputObj.unique_id = query.unique_id;\n    }\n\n    return outputObj;\n}\n\nexport function accessGroup(v) {\n    if (v === undefined) {\n        return 0;\n    }\n\n    if (typeof v === 'number') {\n        if (v > 99 || v < 0) {\n            throw new SkapiError('\"table.access_group\" value should be within a range of 0 ~ 99.', { code: 'INVALID_REQUEST' });\n        }\n    }\n\n    else if (typeof v === 'string') {\n        v = {\n            private: 'private',\n            public: 0,\n            authorized: 1,\n            admin: 99\n        }[v]\n\n        if (v === undefined) {\n            throw new SkapiError('\"table.access_group\" is invalid.', { code: 'INVALID_PARAMETER' });\n        }\n    }\n\n    else {\n        throw new SkapiError('\"table.access_group\" should be type: <number | string>.', { code: 'INVALID_PARAMETER' });\n    }\n\n    if (!this.__user && v) {\n        throw new SkapiError('Unsigned users have no access to records with access group.', { code: 'INVALID_REQUEST' });\n    }\n\n    return v;\n}\n\nconst __index_number_range = 4503599627370496; // +/-\nexport function indexValue(v) {\n    if (typeof v === 'number') {\n        if (v > __index_number_range || v < -__index_number_range) {\n            throw new SkapiError(`Number value should be within range -${__index_number_range} ~ +${__index_number_range}`, { code: 'INVALID_PARAMETER' });\n        }\n        return v;\n    }\n\n    if (typeof v === 'boolean') {\n        return v;\n    }\n\n    if (typeof v === 'string') {\n        return validateIndexStringValue(v, 'index.value');\n    }\n\n    throw new SkapiError(`\"index.value\" should be type: <number | boolean | string>.`, { code: 'INVALID_PARAMETER' });\n}\n\nexport function indexRange(v, query) {\n    if (!query.index || !('value' in query.index)) {\n        throw new SkapiError('\"index.value\" is required.', { code: 'INVALID_PARAMETER' });\n    }\n\n    if (query.index.name === '$record_id') {\n        throw new SkapiError(`Cannot do \"index.range\" on ${query.index.name}`, { code: 'INVALID_PARAMETER' });\n    }\n\n    if (typeof query.index.value !== typeof v) {\n        throw new SkapiError('\"index.range\" type should match the type of \"index.value\".', { code: 'INVALID_PARAMETER' });\n    }\n\n    if (typeof v === 'string') {\n        return validateIndexStringValue(v, 'index.range');\n    }\n\n    return v;\n}\n","import {\n    RecordData,\n    Form,\n    FetchOptions,\n    DatabaseResponse,\n    GetRecordQuery,\n    Condition,\n    PostRecordConfig,\n    ProgressCallback,\n    BinaryFile,\n    FileInfo,\n    DelRecordQuery,\n    Table,\n    Index,\n    Tag,\n    UniqueId\n} from '../Types';\nimport SkapiError from '../main/error';\nimport { extractFormData, fromBase62, isBrowserRuntime } from '../utils/utils';\nimport validator from '../utils/validator';\nimport { request, uploadFiles } from '../utils/network';\nimport { checkAdmin } from './user';\nimport { authentication } from './user';\nimport { accessGroup, indexValue, recordIdOrUniqueId, validateCustomIndexName, validateTableName, validateTag, validateStringByPolicy, indexRange } from './param_restrictions';\n\nconst pendingPrivateAccessKeyRequest: Record<string, Promise<string>> = {};\n\nexport async function normalizeRecord(record: Record<string, any>, _called_from?): Promise<RecordData> {\n    // if (record?.rec) {\n    //     if (_called_from !== 'called from postRecord') {\n    //         let recPost = window.sessionStorage.getItem(`${this.service}:post:${record.rec}`);\n    //         if (recPost) {\n    //             try {\n    //                 record = JSON.parse(recPost);\n    //             }\n    //             catch (err) { }\n    //             window.sessionStorage.removeItem(`${this.service}:post:${record.rec}`);\n    //         }\n    //     }\n    // }\n    const output: Record<string, any> = {\n        user_id: '',\n        record_id: '',\n        updated: 0,\n        uploaded: 0,\n        readonly: false,\n        table: {\n            name: '',\n            access_group: 0,\n            subscription: {\n                is_subscription_record: false,\n                upload_to_feed: false,\n                notify_subscribers: false,\n                feed_referencing_records: false,\n                notify_referencing_records: false\n            }\n        },\n        referenced_count: 0,\n        source: {\n            referencing_limit: null,\n            prevent_multiple_referencing: false,\n            can_remove_referencing_records: false,\n            only_granted_can_reference: false,\n        },\n        ip: '',\n        bin: {}\n    };\n    let is_anonymous = false;\n    function access_group_set(v) {\n        let access_group = v == '**' ? 'private' : parseInt(v);\n        access_group = access_group == 0 ? 'public' : access_group == 1 ? 'authorized' : access_group == 99 ? 'admin' : access_group;\n        return access_group;\n    }\n    const keys = {\n        'ip': (r: string) => {\n            let split_ip = r.split('#');\n            let ip = split_ip[0];\n            if (split_ip.length > 1) {\n                output.unique_id = split_ip[1];\n            }\n            if (ip.slice(-1) === 'R') {\n                output.readonly = true;\n                ip = ip.slice(0, -1);\n            }\n            else {\n                output.readonly = false;\n            }\n            // check if the format of the ip is 0-0-0-0, if it is, convert it to 0.0.0.0\n\n            if (/^\\d{1,3}-\\d{1,3}-\\d{1,3}-\\d{1,3}$/.test(ip)) {\n                ip = ip.split('-').join('.');\n                is_anonymous = true;\n            }\n\n            output.ip = ip;\n        },\n        'rec': (r: string) => {\n            if (!r) return;\n            output.record_id = r;\n            let base62timestamp = r.substring(0, r.length - 9); // id: [base62 timestamp][random 5 char][suid 4 char]\n            let uploaded = fromBase62(base62timestamp);\n            output.uploaded = uploaded;\n        },\n        'usr': (r: string) => {\n            output.user_id = r;\n        },\n        'tbl': (r: string) => {\n            if (!r) return;\n            // table/service/group(** | group)/[subscription(user id)/group(00 - 99)]/[tag]\n            if (!output.table.name) {\n                let rSplit = r.split('/');\n                output.table.name = rSplit[0];\n                output.table.access_group = access_group_set(rSplit[2]);\n                if (rSplit?.[3]) {\n                    output.table.subscription.is_subscription_record = true;\n                }\n            }\n        },\n        'usr_tbl': (r: string) => {\n            // user-id/table/service/group(** | group)[/subscription(user id)/group(00 - 99)][/tag]\n            let rSplit = r.split('/');\n            if (!output.user_id) {\n                output.user_id = rSplit[0];\n            }\n            if (!output.table.name) {\n                output.table.name = rSplit[1];\n                output.table.access_group = access_group_set(rSplit[3]);\n                if (rSplit?.[4]) {\n                    output.table.subscription.is_subscription_record = true;\n                }\n            }\n        },\n        'idx': (r: string) => {\n            if (!r) return;\n            let rSplit = r.split('!');\n            let name = rSplit.splice(0, 1)[0];\n            let value = normalizeTypedString('!' + rSplit.join('!'));\n            output.index = {\n                name,\n                value\n            };\n        },\n        'ref': (r: string) => {\n            if (!r) return;\n            output.reference = r.split('/')[0];\n        },\n        'tags': (r: string[]) => {\n            output.tags = r;\n        },\n        'upd': (r: number) => {\n            output.updated = r;\n        },\n        'acpt_mrf': (r: boolean) => {\n            output.source.prevent_multiple_referencing = !r;\n        },\n        'ref_limt': (r: number) => {\n            output.source.referencing_limit = r;\n        },\n        'rfd': (r: number) => {\n            output.referenced_count = r;\n        },\n        'bin': async (r: string[]) => {\n            let binObj: Record<string, any[]> = {};\n            let _ref = output?.reference || null;\n            if (Array.isArray(r)) {\n                const parsedBin = await Promise.all(r.map(async (url) => {\n                    try {\n                        let path = url.split('/').slice(3).join('/');\n                        let splitPath = path.split('/');\n\n                        // Expected path format:\n                        // auth|publ/serviceid/ownerid/uploaderid/records/recordid/access_group/bin/timestamp/size/form_key/filename\n                        if (splitPath.length < 12) {\n                            return null;\n                        }\n\n                        let filename = decodeURIComponent(splitPath[splitPath.length - 1]);\n                        let pathKey = decodeURIComponent(splitPath[10]);\n                        let size = splitPath[9];\n                        let uploaded = splitPath[8];\n                        let access_group = access_group_set(splitPath[6]);\n                        let url_endpoint = url;\n                        if (access_group !== 'public') {\n                            try {\n                                url_endpoint = (await getFile.bind(this)(url, { dataType: 'endpoint', _ref }) as string);\n                            }\n                            catch (err) {\n                                console.error('Error getting signed url for private file:', err);\n                                // Keep the original CDN URL when signed endpoint resolution is unavailable.\n                                url_endpoint = url;\n                            }\n                        }\n\n                        let obj = {\n                            access_group,\n                            filename,\n                            url: url_endpoint,\n                            path,\n                            size: fromBase62(size),\n                            uploaded: fromBase62(uploaded),\n                            getFile: (dataType: 'base64' | 'download' | 'endpoint' | 'blob' | 'text' | 'info', progress?: ProgressCallback) => {\n                                let config = {\n                                    dataType: dataType || 'download',\n                                    progress,\n                                    _ref,\n                                    _update: obj\n                                };\n                                return getFile.bind(this)(url_endpoint, config);\n                            }\n                        };\n\n                        return { pathKey, obj };\n                    }\n                    catch {\n                        return null;\n                    }\n                }));\n\n                for (let parsed of parsedBin) {\n                    if (!parsed) {\n                        continue;\n                    }\n\n                    if (binObj[parsed.pathKey]) {\n                        binObj[parsed.pathKey].push(parsed.obj);\n                        continue;\n                    }\n\n                    binObj[parsed.pathKey] = [parsed.obj];\n                }\n            }\n            output.bin = binObj;\n        },\n        'prv_acs': (r: { [key: string]: string }) => {\n            for (let k in r) {\n                let subscription_config = ['notify_subscribers', 'upload_to_feed', 'feed_referencing_records', 'notify_referencing_records'];\n                if (subscription_config.includes(k)) {\n                    output.table.subscription[k] = r[k];\n                }\n                else {\n                    output.source[k] = r[k];\n                }\n            }\n        },\n        'data': (r: any) => {\n            let data = r;\n            if (r === '!D%{}') {\n                data = {};\n            }\n            else if (r === '!L%[]') {\n                data = [];\n            }\n            output.data = data;\n        }\n    };\n\n    if (record.record_id) {\n        // bypass already normalized records\n        return record as RecordData;\n    }\n\n    for (let k in keys) {\n        if (record.hasOwnProperty(k)) {\n            let exec = keys[k](record[k]);\n            if (exec instanceof Promise) {\n                await exec;\n            }\n        }\n    }\n\n    if (is_anonymous) {\n        output.user_id = 'anonymous:' + output.user_id;\n    }\n\n    return output as RecordData;\n}\n\nfunction normalizeTypedString(v: string) {\n    let value = v.substring(3);\n    let type = v.substring(0, 3);\n\n    switch (type) {\n        case \"!S%\":\n            // !S%string\n            return value;\n        case \"!N%\":\n            // !N%0\n            let splitDec = value.split('.');\n            let calcNumb = Number(splitDec[0]) - 4503599627370496;\n            if (splitDec.length === 1) {\n                return calcNumb;\n            }\n            return parseFloat(calcNumb.toString() + '.' + splitDec[1]);\n        case \"!B%\":\n            // !B%1\n            return value === '1';\n        case \"!L%\":\n        case \"!D%\":\n            // !L%[0, \"hello\"] / !D%{}\n            try {\n                return JSON.parse(value);\n            } catch (err) {\n                throw new SkapiError('Value parse error.', { code: 'PARSE_ERROR' });\n            }\n        default:\n            return v;\n    }\n}\n\nexport async function deleteFiles(params: {\n    endpoints: string | string[], // file endpoints\n}): Promise<RecordData[]> {\n    let { endpoints } = params;\n\n    if (typeof endpoints === 'string') {\n        endpoints = [endpoints];\n    }\n\n    if (!Array.isArray(endpoints)) {\n        throw new SkapiError('\"endpoints\" should be type: array | string.', { code: 'INVALID_PARAMETER' });\n    }\n\n    let updatedRec = await request.bind(this)('del-files', {\n        endpoints,\n        storage: 'records'\n    }, { auth: true, method: 'post' });\n\n    let to_process = [];\n    for (let i in updatedRec) {\n        to_process.push(normalizeRecord.bind(this)(updatedRec[i]));\n    }\n\n    return Promise.all(to_process);\n}\n\nexport async function getFile(\n    url: string, // cdn endpoint url https://xxxx.cloudfront.net/path/file\n    config?: {\n        dataType?: 'base64' | 'download' | 'endpoint' | 'blob' | 'text' | 'info'; // default 'download'\n        expires?: number; // uses url that expires in given seconds. this option does not use the cdn (slow). can be used for private files. (does not work on public files).\n        progress?: ProgressCallback;\n        _ref?: string;\n        _update?: any;\n    }\n): Promise<Blob | string | void | FileInfo> {\n    if (typeof url !== 'string') {\n        throw new SkapiError('\"url\" should be type: string.', { code: 'INVALID_PARAMETER' });\n    }\n\n    let splitQuery = url.split('?');\n    let baseUrl = splitQuery.shift() || '';\n    let queryString = splitQuery.length ? '?' + splitQuery.join('?') : '';\n\n    let validatedBaseUrl = validator.Url(baseUrl);\n    url = validatedBaseUrl + queryString;\n\n    let isValidEndpoint = false;\n    let splitUrl = validatedBaseUrl.split('/');\n    let host = splitUrl[2];\n    let splitHost = host.split('.');\n    let subdomain = null;\n\n    if (splitHost.length === 3 && splitHost[1] === 'skapi') {\n        subdomain = splitHost[0];\n        isValidEndpoint = true;\n    }\n\n    let target_key = splitUrl.slice(3);\n    let needAuth = false;\n    if (!isValidEndpoint) {\n        if (target_key[0] === 'auth' || target_key[0] === 'publ') {\n            try {\n                validator.UserId(target_key[2]);\n                validator.UserId(target_key[3]);\n                needAuth = target_key[0] == 'auth';\n                isValidEndpoint = true;\n            }\n            catch {\n                throw new SkapiError('Invalid file url.', { code: 'INVALID_PARAMETER' });\n            }\n        }\n    }\n\n    let service = subdomain ? null : target_key[1];\n\n    config = validator.Params<NonNullable<typeof config>>(config, {\n        expires: ['number', () => 0],\n        dataType: ['base64', 'blob', 'endpoint', 'text', 'info', () => 'download'],\n        progress: 'function',\n        _ref: [null, 'string'],\n        _update: v => v\n    });\n\n\n    if (config?.dataType === 'info') {\n        // auth(publ)/service-id/owner-id/user-id/records/rec-id/**/file(bin)/sizetag/filename\n        return {\n            url,\n            filename: target_key[target_key.length - 1],\n            fileKey: target_key[target_key.length - 2],\n            access_group: target_key[6] === '**' ? 'private' : target_key[6] === '01' ? 'authorized' : target_key[6] === '00' ? 'public' : parseInt(target_key[6]),\n            uploader: target_key[3],\n            record_id: target_key[4] === 'records' ? target_key[5] : 'N/A',\n            filesize: fromBase62(target_key[9]),\n            uploaded: fromBase62(target_key[8]),\n        }\n    }\n\n    let filename = url.split('/').slice(-1)[0];\n\n    // if ((config?.dataType === 'blob' || config?.dataType === 'base64') && needAuth) {\n    //     // when downloading blob, use signed url\n    //     config.expires = 60;\n    // }\n\n    let expires = config.expires;\n    if (expires) {\n        if (!isValidEndpoint) {\n            throw new SkapiError('Expires option can only be used on skapi cdn endpoints.', { code: 'INVALID_PARAMETER' });\n        }\n\n        if (expires < 0) {\n            throw new SkapiError('\"config.expires\" should be > 0. (seconds)', { code: 'INVALID_PARAMETER' });\n        }\n\n        let params: Record<string, any> = {\n            request: subdomain ? 'get-host' : 'get',\n            id: subdomain || target_key[5],\n            key: url,\n            expires\n        }\n\n        if (service) {\n            params.service = service\n        }\n\n        url = (await request.bind(this)('get-signed-url', params,\n            { auth: true }\n        )).url;\n    }\n\n    else if (needAuth) {\n        let currTime = Math.floor(Date.now() / 1000);\n\n        if (!this.bearerToken && (!this.session?.idToken?.payload?.exp || this.session.idToken.payload.exp < currTime)) {\n            this.log('getFile:requesting new token', null);\n            try {\n                await authentication.bind(this)().getSession({ refreshToken: true });\n                this.log('getFile:received new tokens', {\n                    exp: this.session?.idToken?.payload?.exp,\n                    currTime,\n                    expiresIn: this.session?.idToken?.payload?.exp - currTime,\n                    token: this.session?.accessToken?.jwtToken,\n                    refreshToken: this.session?.refreshToken?.token\n                });\n            }\n            catch (err) {\n                this.log('getFile:new token error', err);\n                throw new SkapiError('User login is required.', { code: 'INVALID_REQUEST' });\n            }\n        }\n\n        let token = this.bearerToken || this.session?.idToken?.jwtToken; // idToken\n\n        if (!token || !this.user?.user_id) {\n            throw new SkapiError('User login is required.', { code: 'INVALID_REQUEST' });\n        }\n\n        url += `${url.includes('?') ? '&' : '?'}t=${encodeURIComponent(token)}`;\n\n        let access_group = target_key[6] === '**' ? '**' : parseInt(target_key[6]);\n        let user_access_group = this.user?.access_group ?? -1;\n\n        if (this.user.user_id !== target_key[3] && (access_group === '**' || user_access_group < access_group)) {\n            let record_id = target_key[5];\n            if (this.__private_access_key[record_id] && typeof this.__private_access_key[record_id] === 'string') {\n                url += `&p=${encodeURIComponent(this.__private_access_key[record_id])}`;\n            }\n            else if (this.owner !== this.host) {\n                try {\n                    let p = await this.requestPrivateRecordAccessKey({ record_id, reference_id: config?._ref });\n                    url += `&p=${encodeURIComponent(p)}`;\n                } catch (err) { }\n            }\n        }\n    }\n\n    if (config?.dataType === 'endpoint') {\n        if (config._update) {\n            // updates the url in the record (when called from the record bin object)\n            config._update.url = url;\n        }\n        return url;\n    }\n\n    if (config?.dataType === 'download') {\n        let a = document.createElement('a');\n        // Set the href attribute to the file URL\n        a.href = url;\n        document.body.appendChild(a);\n        a.setAttribute('download', filename);\n        a.target = '_blank';\n        a.click();\n        document.body.removeChild(a);\n        return null;\n    }\n\n    let blob: Promise<Blob | string> = new Promise(async (res, rej) => {\n        try {\n            let b = await request.bind(this)(\n                url,\n                null,\n                { method: 'get', contentType: null, responseType: config?.dataType === 'text' ? 'text' : 'blob', fetchOptions: { progress: config?.progress } },\n                { ignoreService: true }\n            );\n            if (config?.dataType === 'base64') {\n                const reader = new FileReader();\n                reader.onloadend = () => res((reader.result as string));\n                reader.readAsDataURL(b);\n            }\n            else {\n                res(b);\n            }\n        } catch (err) {\n            rej(err);\n        }\n    });\n\n    return blob;\n}\n\nasync function getQuery(query, isDel = false) {\n    query = extractFormData(query, { ignoreEmpty: true }).data || {};\n\n    let is_reference_fetch = '';\n    let rec_or_uniq = recordIdOrUniqueId(query);\n\n    if (rec_or_uniq) {\n        query = rec_or_uniq;\n        is_reference_fetch = query.record_id || query.unique_id;\n\n        if (typeof is_reference_fetch === 'string') {\n            if (typeof this.__private_access_key?.[is_reference_fetch] === 'string') {\n                query.private_key = this.__private_access_key?.[is_reference_fetch] || undefined;\n            }\n            if (this.__my_unique_ids[is_reference_fetch]) {\n                if (isDel) {\n                    delete this.__my_unique_ids[is_reference_fetch];\n                }\n                else {\n                    query.record_id = this.__my_unique_ids[is_reference_fetch];\n                    // delete query.unique_id;\n                }\n            }\n        }\n    }\n    else {\n        let isAdmin = await checkAdmin.bind(this)();\n        let ref: any = query?.reference;\n        let ref_user_is_me = false;\n\n        if (typeof ref === 'object' && Object.keys(ref).length) {\n            if (ref?.record_id || ref?.unique_id) {\n                // if (ref.unique_id && this.__my_unique_ids[ref.unique_id]) {\n                //     ref.record_id = this.__my_unique_ids[ref.unique_id];\n                //     delete ref.unique_id;\n                // }\n\n                is_reference_fetch = ref.record_id || ref.unique_id;\n\n                if (is_reference_fetch && typeof this.__private_access_key?.[is_reference_fetch] === 'string') {\n                    query.private_key = this.__private_access_key?.[is_reference_fetch] || undefined;\n                }\n\n                query.reference = is_reference_fetch;\n            }\n            else if (ref?.user_id) {\n                ref_user_is_me = ref.user_id === this.user?.user_id;\n                query.reference = ref.user_id;\n            }\n        }\n\n        if (typeof query?.table === 'string') {\n            query.table = {\n                name: query.table,\n                access_group: 0\n            };\n        }\n\n        if (query.index) {\n            if (query.index.hasOwnProperty('range') && query.index.hasOwnProperty('condition')) {\n                delete query.index.range;\n            }\n        }\n\n        const buildStruct = (query) => {\n            return {\n                table: {\n                    name: v => validateTableName(v, 'table.name'),\n                    access_group: accessGroup.bind(this),\n                    subscription: (v: any) => validator.UserId(v, 'User ID in \"subscription\"')\n                },\n                reference: 'string',\n                index: {\n                    name: ['$updated', '$uploaded', '$referenced_count', '$user_id', (v: string) => {\n                        return validateCustomIndexName(v, 'index.name');\n                    }],\n                    value: (v: number | boolean | string) => {\n                        const indexTypes = {\n                            '$updated': 'number',\n                            '$uploaded': 'number',\n                            '$referenced_count': 'number',\n                            '$user_id': validator.UserId\n                        };\n\n                        if (indexTypes.hasOwnProperty(query.index.name)) {\n                            let tp = indexTypes[query.index.name];\n\n                            if (typeof tp === 'function') {\n                                return tp(v);\n                            }\n\n                            if (tp !== typeof v) {\n                                throw new SkapiError(`\"index.value\" should be type: ${tp}.`, { code: 'INVALID_PARAMETER' });\n                            }\n\n                            return v;\n                        }\n\n                        if (typeof v === 'string' && !v) {\n                            return \"\";\n                        }\n\n                        return indexValue(v);\n                    },\n                    condition: ['gt', 'gte', 'lt', 'lte', '>', '>=', '<', '<=', '=', 'eq'],\n                    range: (v: number | boolean | string) => indexRange(v, query)\n                },\n                tag: (v: string) => {\n                    if (v === null || v === undefined) {\n                        return v;\n                    }\n                    if (typeof v === 'string') {\n                        return validateTag(v, 'tag');\n                    }\n                    else {\n                        throw new SkapiError('\"tag\" should be type: string.', { code: 'INVALID_PARAMETER' });\n                    }\n                },\n                private_key: 'string'\n            }\n        }\n\n        query = validator.Params(query || {}, buildStruct(query), ref_user_is_me || isAdmin ? [] : ['table'], { ignoreEmpty: true });\n    }\n    return {\n        query,\n        is_reference_fetch\n    }\n}\n\nexport async function getRecords(query: GetRecordQuery & { private_key?: string; }, fetchOptions?: FetchOptions): Promise<DatabaseResponse<RecordData>> {\n    await this.__connection;\n\n    let q = await getQuery.bind(this)(query);\n    let is_reference_fetch = q.is_reference_fetch;\n\n    // TODO: THINK ABOUT HOW TO HANDLE PRIVATE KEY FOR REFERENCE FETCH.\n    // if (is_reference_fetch && typeof this.__private_access_key[is_reference_fetch] === 'string') {\n    //     q.query.private_key = this.__private_access_key[is_reference_fetch] || undefined;\n    // }\n\n    let result = await request.bind(this)(\n        'get-records',\n        q.query,\n        {\n            fetchOptions,\n            auth: !!this.__user,\n            method: !!this.__user ? 'post' : 'get'\n        }\n    );\n\n    if (is_reference_fetch && result?.reference_private_key && typeof result.reference_private_key === 'string') {\n        this.__private_access_key[is_reference_fetch] = result.reference_private_key;\n    }\n\n    let to_process = [];\n    for (let i in result.list) {\n        to_process.push(normalizeRecord.bind(this)(result.list[i]));\n    }\n\n    result.list = await Promise.all(to_process);\n    return result;\n}\n\nfunction setupPostRecordConfig(config: PostRecordConfig & { data?: any; }) {\n    let is_reference_post = \"\";\n    let files = [];\n    let _config = validator.Params(config || {}, {\n        record_id: (v) => validateStringByPolicy(v, 'record_id', {\n            allowEmpty: false,\n            onlyAlphanumeric: true,\n        }),\n        unique_id: ['string', null],\n        readonly: 'boolean',\n        table: {\n            name: v => validateTableName(v, 'table.name'),\n            subscription: [null, {\n                is_subscription_record: 'boolean',\n                upload_to_feed: 'boolean',\n                notify_subscribers: 'boolean',\n                feed_referencing_records: 'boolean',\n                notify_referencing_records: 'boolean',\n            }],\n            access_group: accessGroup.bind(this),\n        },\n        source: {\n            referencing_limit: (v: number) => {\n                if (v === null) {\n                    return null;\n                }\n\n                else if (typeof v === 'number') {\n                    if (0 > v) {\n                        throw new SkapiError(`\"reference_limit\" should be >= 0`, { code: 'INVALID_PARAMETER' });\n                    }\n\n                    if (v > 4503599627370546) {\n                        throw new SkapiError(`\"reference_limit\" should be <= 4503599627370546`, { code: 'INVALID_PARAMETER' });\n                    }\n\n                    return v;\n                }\n\n                throw new SkapiError(`\"reference_limit\" should be type: <number | null>`, { code: 'INVALID_PARAMETER' });\n            },\n            prevent_multiple_referencing: 'boolean',\n            can_remove_referencing_records: 'boolean',\n            only_granted_can_reference: 'boolean',\n            allow_granted_to_grant_others: 'boolean',\n            referencing_index_restrictions: v => {\n                if (v === undefined) {\n                    return undefined;\n                }\n\n                if (!v) {\n                    return null;\n                }\n\n                if (Array.isArray(v) && !v.length) {\n                    return null;\n                }\n\n                let p = {\n                    name: v => validateCustomIndexName(v, '\"name\" in \"index_restrictions\"'),\n                    value: v => indexValue(v),\n                    condition: ['gt', 'gte', 'lt', 'lte', '>', '>=', '<', '<=', '=', 'eq', '!=', 'ne', () => null],\n                    range: val => {\n                        if (val !== null && typeof v.value !== typeof val) {\n                            throw new SkapiError('Index restriction \"range\" type should match the type of \"value\".', { code: 'INVALID_PARAMETER' });\n                        }\n                        if (!v.hasOwnProperty('value')) {\n                            throw new SkapiError('Index restriction \"value\" is required.', { code: 'INVALID_PARAMETER' });\n                        }\n                        return val;\n                    }\n                }\n\n                if (!Array.isArray(v)) {\n                    v = [v];\n                }\n\n                let qq = v.map(vv => validator.Params(vv, p, ['name']));\n                if (qq.length) {\n                    for (let q of qq) {\n                        if (q.condition && q.hasOwnProperty('range')) {\n                            delete q.range;\n                        }\n                    }\n                }\n                return qq;\n            },\n        },\n        reference: v => {\n            if (v === null) {\n                return { record_id: null };\n            }\n            if (!v) {\n                return undefined;\n            }\n            if (typeof v === 'string') {\n                is_reference_post = v;\n                if (this.__my_unique_ids[v]) {\n                    return this.__my_unique_ids[v];\n                }\n                return v;\n            }\n\n            if (typeof v !== 'object') {\n                throw new SkapiError('\"reference\" should be type: <string | object>.', { code: 'INVALID_PARAMETER' });\n            }\n\n            return validator.Params(v, {\n                unique_id: 'string',\n                record_id: v => {\n                    if (v === null || v === undefined) {\n                        return v;\n                    }\n                    is_reference_post = v;\n                    if (typeof this.__private_access_key?.[v] === 'string') {\n                        config.reference_private_key = this.__private_access_key[v] || undefined;\n                    }\n                    return validateStringByPolicy(v, 'reference.record_id', {\n                        allowEmpty: false,\n                        onlyAlphanumeric: true,\n                    });\n                }\n            });\n        },\n        index: [null, {\n            name: v => validateCustomIndexName(v, 'index.name'),\n            value: v => indexValue(v)\n        }],\n        tags: (v: string | string[]) => {\n            if (v === null || v === undefined) {\n                return v;\n            }\n            if (typeof v === 'string') {\n                v = v.split(',').map(t => t.trim());\n            }\n            if (!Array.isArray(v)) {\n                throw new SkapiError('\"tag\" should be type: <string | string[]>.', { code: 'INVALID_PARAMETER' });\n            }\n            return v.map(t => validateTag(t, 'tag'));\n        },\n        remove_bin: (v: string[] | BinaryFile[] | null) => {\n            if (!v) {\n                return null;\n            }\n\n            let arr = []\n            if (Array.isArray(v)) {\n                for (let i of v) {\n                    if (typeof i === 'string') {\n                        arr.push(decodeURIComponent(i.split('?')[0]));\n                    }\n                    else if (i.url && i.size && i.filename) {\n                        let hostUrl = i.url.split('/').slice(0, 3).join('/');\n                        let url = hostUrl + '/' + i.path;\n                        arr.push(url);\n                    }\n                    else {\n                        throw new SkapiError(`\"remove_bin\" should be type: <string[] | BinaryFile[] | null>`, { code: 'INVALID_PARAMETER' });\n                    }\n                }\n            }\n            else {\n                throw new SkapiError(`\"remove_bin\" should be type: <string[] | BinaryFile[] | null>`, { code: 'INVALID_PARAMETER' });\n            }\n\n            return arr;\n        },\n        progress: 'function',\n        data: v => v\n    }, [], {\n        precall: (pc) => {\n            const data = pc?.data || {};\n\n            if (!data?.record_id && !data.table) {\n                throw new SkapiError('\"table.name\" is required.', { code: 'INVALID_PARAMETER' });\n            }\n\n            if (typeof data.table === 'string') {\n                data.table = {\n                    name: data.table,\n                    access_group: 0\n                };\n            }\n\n            if (pc.files) {\n                files = pc.files;\n            }\n        }\n    });\n\n    let progress = config.progress || null;\n\n    // callbacks should be removed after cocochex\n    delete _config.progress;\n\n    if (!this.__user) {\n        const hasEnabledSubscriptionOptions = !!(\n            _config.table?.subscription?.is_subscription_record\n            || _config.table?.subscription?.upload_to_feed\n            || _config.table?.subscription?.notify_subscribers\n            || _config.table?.subscription?.feed_referencing_records\n            || _config.table?.subscription?.notify_referencing_records\n        );\n\n        if (_config.record_id) {\n            throw new SkapiError('Public users cannot update existing records.', { code: 'INVALID_REQUEST' });\n        }\n        if (_config.table.access_group !== 'public' && _config.table.access_group !== 0) {\n            throw new SkapiError('Public users can only post records to public tables.', { code: 'INVALID_REQUEST' });\n        }\n        if (hasEnabledSubscriptionOptions) {\n            throw new SkapiError('Public users cannot post subscription records.', { code: 'INVALID_REQUEST' });\n        }\n        if (_config.remove_bin) {\n            throw new SkapiError('Public users cannot remove files from records.', { code: 'INVALID_REQUEST' });\n        }\n        if (_config.unique_id) {\n            throw new SkapiError('Public users cannot set unique_id for records.', { code: 'INVALID_REQUEST' });\n        }\n    }\n    return { config: _config, progress, is_reference_post, files };\n}\n\nexport async function bulkPostRecords(params) {\n    await this.__connection;\n\n    if (!Array.isArray(params) || !params.length) {\n        throw new SkapiError('\"params\" should be a non-empty array.', { code: 'INVALID_PARAMETER' });\n    }\n\n    let is_public = !this.__user;\n    let reference_posts = [];\n    let service = undefined;\n    let owner = undefined;\n    let progress = null;\n\n    let validatedBulk = params.map((config, idx) => {\n        if (!config || typeof config !== 'object' || Array.isArray(config)) {\n            throw new SkapiError(`\"params[${idx}]\" should be type: <object>.`, { code: 'INVALID_PARAMETER' });\n        }\n\n        let mangled = setupPostRecordConfig.bind(this)(config) as {config: PostRecordConfig & { service?: string; owner?: string;  }; is_reference_post?: string;};\n        let _config = mangled.config;\n        if (mangled.is_reference_post) {\n            reference_posts.push(mangled.is_reference_post);\n        }\n        if (typeof _config.progress === 'function' && progress === null) {\n            progress = _config.progress;\n        }\n\n        if (_config.service !== undefined) {\n            if (service === undefined) {\n                service = _config.service;\n            }\n            else if (service !== _config.service) {\n                throw new SkapiError('All bulk params should share the same \"service\" value.', { code: 'INVALID_PARAMETER' });\n            }\n        }\n\n        if (_config.owner !== undefined) {\n            if (owner === undefined) {\n                owner = _config.owner;\n            }\n            else if (owner !== _config.owner) {\n                throw new SkapiError('All bulk params should share the same \"owner\" value.', { code: 'INVALID_PARAMETER' });\n            }\n        }\n\n        delete _config.progress;\n        delete _config.service;\n        delete _config.owner;\n\n        return _config;\n    });\n\n    let postData = {\n        _is_bulk_: validatedBulk,\n        service: \"\",\n        owner: \"\"\n    };\n\n    if (service !== undefined) {\n        postData.service = service;\n    }\n\n    if (owner !== undefined) {\n        postData.owner = owner;\n    }\n\n    let options = { auth: !!this.__user, method: 'post' };\n    let fetchOptions = {};\n\n    // if (typeof progress === 'function') {\n    //     fetchOptions.progress = progress;\n    // }\n\n    if (Object.keys(fetchOptions).length) {\n        Object.assign(options, { fetchOptions });\n    }\n\n    let recList = await request.bind(this)('post-record', postData, options);\n    let records = await Promise.all(recList.map((rec) => normalizeRecord.bind(this)(rec, 'called from postRecord')));\n\n    for (let i = 0; i < recList.length; i++) {\n        let rec = recList[i];\n        let record = records[i];\n\n        // if (rec?.rec) {\n        //     window.sessionStorage.setItem(`${this.service}:post:${rec.rec}`, JSON.stringify(rec));\n        // }\n\n        if (typeof rec?.reference_private_key === 'string') {\n            for (let ref of reference_posts) {\n                this.__private_access_key[ref] = rec.reference_private_key;\n            }\n        }\n\n        if (record?.unique_id) {\n            this.__my_unique_ids[record.unique_id] = record.record_id;\n        }\n    }\n\n    // if (Object.keys(this.__my_unique_ids).length) {\n    //     window.sessionStorage.setItem(`${this.service}:uniqueids`, JSON.stringify(this.__my_unique_ids));\n    // }\n\n    return records;\n}\n\nexport async function postRecord(\n    form: Form<Record<string, any>> | null | undefined,\n    config: PostRecordConfig,\n    files?: { name: string, file: File }[],\n): Promise<RecordData> {\n    await this.__connection;\n\n    if (!config) {\n        throw new SkapiError('\"config\" argument is required.', { code: 'INVALID_PARAMETER' });\n    }\n\n    let postConf = setupPostRecordConfig.bind(this)(config);\n    let _config = postConf.config;\n    let progress = postConf.progress;\n    let is_reference_post = postConf.is_reference_post;\n\n    let options: { [key: string]: any } = { auth: !!this.__user, method: 'post' };\n\n    let to_bin: { name: string, file: File }[] = [];\n    let extractedForm = extractFormData(form);\n    if (files && Array.isArray(files) && files.length) {\n        // { name: string, file: File }[]\n        to_bin = to_bin.concat(files);\n    }\n    if (extractedForm.files && Array.isArray(extractedForm.files) && extractedForm.files.length) {\n        // { name: string, file: File }[]\n        to_bin = to_bin.concat(extractedForm.files);\n    }\n\n    let postData = null;\n    postData = Object.assign({ data: extractedForm.data }, _config);\n\n    let fetchOptions: { [key: string]: any } = {};\n\n    if (typeof progress === 'function') {\n        fetchOptions.progress = progress;\n    }\n\n    if (Object.keys(fetchOptions).length) {\n        Object.assign(options, { fetchOptions });\n    }\n    let rec = await request.bind(this)('post-record', postData, options);\n    if (isBrowserRuntime() && to_bin.length) {\n        let bin_formData = new FormData();\n        for (let f of to_bin) {\n            bin_formData.append(f.name, f.file, f.file.name);\n        }\n        let uploadFileParams = {\n            record_id: rec.rec,\n            progress\n        }\n        if (_config.hasOwnProperty('service')) {\n            uploadFileParams['service'] = _config.service;\n        }\n        let { bin_endpoints } = await uploadFiles.bind(this)(bin_formData, uploadFileParams);\n        if (!rec.bin) {\n            rec.bin = bin_endpoints;\n        }\n        else {\n            rec.bin.push(...bin_endpoints);\n        }\n    }\n\n    if (is_reference_post && typeof rec?.reference_private_key === 'string') {\n        this.__private_access_key[is_reference_post] = rec.reference_private_key;\n    }\n\n    // window.sessionStorage.setItem(`${this.service}:post:${rec.rec}`, JSON.stringify(rec));\n\n    let record = await normalizeRecord.bind(this)(rec, 'called from postRecord');\n    if (record.unique_id) {\n        this.__my_unique_ids[record.unique_id] = record.record_id;\n        if (isBrowserRuntime()) {\n            window.sessionStorage.setItem(`${this.service}:uniqueids`, JSON.stringify(this.__my_unique_ids));\n        }\n    }\n\n    return record;\n}\n\nexport async function getTables(\n    /** If null fetch all list of tables. */\n    query: {\n        table: string;\n        /** Condition operator of table name. */\n        condition?: Condition;\n    },\n    fetchOptions?: FetchOptions\n): Promise<DatabaseResponse<Table>> {\n    let res = await request.bind(this)('get-table', validator.Params(query || {}, {\n        table: 'string',\n        condition: ['gt', 'gte', 'lt', 'lte', '>', '>=', '<', '<=', '=', 'eq', '!=', 'ne']\n    }), Object.assign({ auth: !!this.__user }, { fetchOptions }));\n\n    let convert = {\n        'cnt_rec': 'number_of_records',\n        'tbl': 'table',\n        'srvc': 'service'\n    };\n\n    if (Array.isArray(res?.list)) {\n        for (let t of res.list) {\n            for (let k in convert) {\n                if (t.hasOwnProperty(k)) {\n                    t[convert[k]] = t[k];\n                    delete t[k];\n                }\n            }\n        }\n    }\n\n    return res;\n}\n\nexport async function getIndexes(\n    query: {\n        /** Table name */\n        table: string;\n        /** Index name. When period is at the end of name, querys nested index keys. */\n        index?: string;\n        /** Queries order by */\n        order?: {\n            /** Key name to order by. */\n            by: 'average_number' | 'total_number' | 'number_count' | 'average_bool' | 'total_bool' | 'bool_count' | 'string_count' | 'index_name';\n            /** Value to query. */\n            value?: number | boolean | string;\n            condition?: Condition;\n        };\n    },\n    fetchOptions?: FetchOptions\n): Promise<DatabaseResponse<Index>> {\n    if (!query?.table) {\n        throw new SkapiError('\"table\" is required.', { code: 'INVALID_PARAMETER' });\n    }\n\n    let p:any = validator.Params(\n        query || {},\n        {\n            table: 'string',\n            index: (v: string) => validateCustomIndexName(v, 'index.name'),\n            order: {\n                by: [\n                    'average_number',\n                    'total_number',\n                    'number_count',\n                    'average_bool',\n                    'total_bool',\n                    'bool_count',\n                    'string_count',\n                    'index_name',\n                    'number_of_records'\n                ],\n                value: ['string', 'number', 'boolean'],\n                condition: ['gt', 'gte', 'lt', 'lte', '>', '>=', '<', '<=', '=', 'eq', '!=', 'ne']\n            }\n        },\n        ['table']\n    );\n\n    if (p.hasOwnProperty('order')) {\n        if (!p.order?.by) {\n            throw new SkapiError('\"order.by\" is required.', { code: 'INVALID_PARAMETER' });\n        }\n\n        if (p.order.hasOwnProperty('condition') && !p.order.hasOwnProperty('value')) {\n            throw new SkapiError('\"value\" is required for \"condition\".', { code: 'INVALID_PARAMETER' });\n        }\n\n        if (p.hasOwnProperty('index')) {\n            if (p.index.substring(p.index.length - 1) !== '.') {\n                throw new SkapiError('\"index\" should be a parent index name of the compound index when using \"order.by\"', { code: 'INVALID_PARAMETER' });\n            }\n        }\n    }\n\n    let res = await request.bind(this)(\n        'get-index',\n        p,\n        Object.assign(\n            { auth: !!this.__user },\n            { fetchOptions }\n        )\n    );\n\n    let convert = {\n        'cnt_bool': 'boolean_count',\n        'cnt_numb': 'number_count',\n        'totl_numb': 'total_number',\n        'totl_bool': 'total_bool',\n        'avrg_numb': 'average_number',\n        'avrg_bool': 'average_bool',\n        'cnt_str': 'string_count'\n    };\n\n    if (Array.isArray(res?.list)) {\n        res.list = res.list.map((i: Record<string, any>) => {\n            let iSplit = i.idx.split('/');\n            let resolved: Record<string, any> = {\n                table: iSplit[1],\n                index: iSplit[2],\n                number_of_records: i.cnt_rec\n            };\n\n            for (let k in convert) {\n                if (Object.prototype.hasOwnProperty.call(i, k)) {\n                    resolved[convert[k]] = i[k];\n                }\n            }\n\n            return resolved;\n        });\n    }\n\n    return res;\n}\n\nexport async function getTags(\n    query?: {\n        /** Table name */\n        table: string;\n        /** Tag name */\n        tag?: string;\n        /** String query condition for tag name. */\n        condition?: Condition;\n    },\n    fetchOptions?: FetchOptions\n): Promise<DatabaseResponse<Tag>> {\n\n    let res = await request.bind(this)(\n        'get-tag',\n        validator.Params(query || {},\n            {\n                table: 'string',\n                tag: 'string',\n                condition: ['gt', 'gte', 'lt', 'lte', '>', '>=', '<', '<=', '=', 'eq', '!=', 'ne']\n            }\n        ),\n        Object.assign({ auth: !!this.__user }, { fetchOptions })\n    );\n\n    if (Array.isArray(res?.list)) {\n        res.list = res.list.map(item => {\n            let tSplit = item.tag.split('/');\n            return {\n                table: tSplit[1],\n                tag: tSplit[0],\n                number_of_records: item.cnt_rec\n            };\n        });\n    }\n\n    return res;\n}\n\nexport async function getUniqueId(\n    query?: Form<{\n        /** Unique ID */\n        unique_id?: string;\n        /** String query condition for tag name. */\n        condition?: Condition;\n    }>,\n    fetchOptions?: FetchOptions\n): Promise<DatabaseResponse<UniqueId>> {\n\n    let res = await request.bind(this)(\n        'get-uniqueid',\n        validator.Params(query || {},\n            {\n                unique_id: 'string',\n                condition: ['gt', 'gte', 'lt', 'lte', '>', '>=', '<', '<=', '=', 'eq', '!=', 'ne']\n            }\n        ),\n        Object.assign({ auth: !!this.__user }, { fetchOptions })\n    );\n\n    if (Array.isArray(res?.list)) {\n        for (let i in res.list) {\n            let item = res.list[i];\n            res.list[i] = {\n                unique_id: item.unq,\n                record_id: item.rec\n            };\n        }\n    }\n\n    return res;\n}\n\nexport async function deleteRecords(query: DelRecordQuery & { private_key?: string; }, fetchOptions?: FetchOptions): Promise<string | DatabaseResponse<RecordData>> {\n    await this.__connection;\n\n    let q = await getQuery.bind(this)(query, true);\n    let is_reference_fetch = q.is_reference_fetch;\n    let result = await request.bind(this)('del-records', q.query, { auth: true, fetchOptions });\n    if (is_reference_fetch && typeof result?.reference_private_key === 'string') {\n        this.__private_access_key[is_reference_fetch] = result.reference_private_key;\n    }\n\n    return result?.message || result;\n}\n\nexport function grantPrivateRecordAccess(params: {\n    record_id: string;\n    user_id: string | string[];\n}) {\n    return recordAccess.bind(this)({\n        record_id: params.record_id,\n        user_id: params.user_id,\n        execute: 'add'\n    });\n}\n\nexport function removePrivateRecordAccess(params: {\n    record_id: string;\n    user_id: string | string[];\n}) {\n    return recordAccess.bind(this)({\n        record_id: params.record_id,\n        user_id: params.user_id || null,\n        execute: 'remove'\n    });\n}\n\nexport async function listPrivateRecordAccess(p: {\n    record_id?: string;\n    user_id?: string | string[];\n}, fetchOptions?: FetchOptions): Promise<DatabaseResponse<{ record_id: string; user_id: string; }>> {\n    let params = {\n        record_id: p.record_id || undefined,\n        user_id: p.user_id || undefined,\n        execute: 'list'\n    };\n\n    if (!params.record_id && !params.user_id) {\n        throw new SkapiError(`Either record_id or user_id must be provided.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    if (params.user_id) {\n        if (typeof params.user_id === 'string') {\n            validator.UserId(params.user_id);\n            params.user_id = [params.user_id];\n        }\n        else if (Array.isArray(params.user_id)) {\n            for (let u of params.user_id) {\n                validator.UserId(u);\n            }\n        }\n        else {\n            throw new SkapiError(`user_id should be type: <string | string[]>`, { code: 'INVALID_PARAMETER' });\n        }\n    }\n\n    let mapper = (i: Record<string, any>) => {\n        if (i.rec_usr) {\n            i.record_id = i.rec_usr.split('/')[0];\n            i.user_id = i.rec_usr.split('/')[1];\n        }\n        else if (i.usr_rec) {\n            i.user_id = i.usr_rec.split('/')[0];\n            i.record_id = i.usr_rec.split('/')[1];\n        }\n        return i;\n    };\n\n    let list = await request.bind(this)(\n        'grant-private-access',\n        params,\n        { auth: true, fetchOptions }\n    );\n\n    list.list = list.list.map(mapper);\n\n    return list;\n}\n\nexport function requestPrivateRecordAccessKey(params: { record_id: string, reference_id?: string }): Promise<string> {\n    let record_id: string | string[] = params.record_id;\n    let reference_id = params.reference_id || undefined;\n    if (!record_id) {\n        throw new SkapiError(`Record ID is required.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    if (typeof record_id !== 'string') {\n        throw new SkapiError(`Record ID should be type: <string | string[]>`, { code: 'INVALID_PARAMETER' });\n    }\n\n    if (reference_id && typeof reference_id !== 'string') {\n        throw new SkapiError(`Reference ID should be type: <string>`, { code: 'INVALID_PARAMETER' });\n    }\n\n    if (typeof this.__private_access_key[record_id] === 'string') {\n        return Promise.resolve(this.__private_access_key[record_id]);\n    }\n\n    if (pendingPrivateAccessKeyRequest[record_id]) {\n        return pendingPrivateAccessKeyRequest[record_id];\n    }\n\n    let res = request\n        .bind(this)(\n            'request-private-access-key',\n            { record_id, reference_id },\n            { auth: true }\n        )\n        .then((r: any) => {\n            let privateKey = typeof r === 'string' ? r : r?.private_key;\n            if (typeof privateKey !== 'string') {\n                throw new SkapiError('Invalid private access key response.', { code: 'ERROR' });\n            }\n\n            this.__private_access_key[record_id] = privateKey;\n            return privateKey;\n        })\n        .finally(() => {\n            delete pendingPrivateAccessKeyRequest[record_id];\n        });\n\n    pendingPrivateAccessKeyRequest[record_id] = res;\n\n    return res;\n}\n\nfunction recordAccess(params: {\n    record_id: string;\n    user_id: string | string[];\n    execute: 'add' | 'remove';\n}): Promise<any> {\n    let execute = params.execute;\n    let req = validator.Params(params,\n        {\n            record_id: 'string',\n            user_id: (v: string | string[]) => {\n                if (!v) {\n                    throw new SkapiError(`User ID is required.`, { code: 'INVALID_PARAMETER' });\n                }\n\n                let id = v;\n                if (typeof id === 'string') {\n                    id = [id];\n                }\n\n                if (id.length > 100) {\n                    throw new SkapiError(`Cannot process more than 100 users at once.`, { code: 'INVALID_REQUEST' });\n                }\n\n                for (let i of id) {\n                    validator.UserId(i, 'User ID in \"user_id\"');\n                }\n\n                return id;\n            },\n            execute: ['add', 'remove']\n        },\n        [\n            'execute',\n            'record_id',\n            'user_id'\n        ]\n    );\n\n    if (!req.user_id) {\n        req.user_id = null;\n    }\n\n    return request.bind(this)(\n        'grant-private-access',\n        req,\n        { auth: true }\n    );\n}\n\n","import { SkapiError } from \"../Main\";\nimport { RTCResolved, RTCEvent, RTCConnectorParams, RTCReceiverParams, WebSocketMessage, RTCConnector } from \"../Types\";\nimport { extractFormData } from \"../utils/utils\";\nimport validator from \"../utils/validator\";\n\nexport const __peerConnection: { [sender: string]: RTCPeerConnection } = {};\nexport const __dataChannel: { [sender: string]: { [label: string]: RTCDataChannel } } = {};\nexport const __caller_ringing: { [recipient: string]: (v: any) => void } = {};\nexport const __receiver_ringing: { [caller: string]: string } = {};\nexport const __rtcEvents: { [sender: string]: (v: any) => void } = {};\n\nlet __rtcCandidatesBuffer: { [sender: string]: any[] } = {};\nlet __rtcSdpOfferBuffer: { [sender: string]: any[] } = {};\n\nfunction setBuffer(buffer: { [recipient: string]: any[] }, recipient: string, item: any) {\n    if (!buffer[recipient]) {\n        buffer[recipient] = [];\n    }\n    buffer[recipient].push(item);\n}\n\nasync function processBuffer(buffer: { [recipient: string]: any[] }, recipient: string, fn: (item: any) => any): Promise<any[]> {\n    let proceed = [];\n    if (buffer[recipient]) {\n        for (let v of buffer[recipient]) {\n            if (v) {\n                let process = fn(v);\n                if (process instanceof Promise) {\n                    process = await process;\n                }\n                proceed.push(process);\n            }\n        };\n        delete buffer[recipient];\n    }\n    return proceed;\n}\n\nexport async function answerSdpOffer(offer: any, recipient: string) {\n    if (!this?.session?.accessToken?.jwtToken) {\n        throw new SkapiError('Access token is required.', { code: 'INVALID_PARAMETER' });\n    }\n\n    let socket: WebSocket = await this.__socket;\n    async function sendAnswer(offer, recipient, socket) {\n        this.log('answerSdpOffer from', recipient);\n        await __peerConnection[recipient].setRemoteDescription(new RTCSessionDescription(offer));\n        const answer = await __peerConnection[recipient].createAnswer();\n        await __peerConnection[recipient].setLocalDescription(answer);\n        socket.send(JSON.stringify({\n            action: 'rtc',\n            uid: recipient,\n            content: { sdpanswer: answer },\n            token: this.session.accessToken.jwtToken\n        }));\n    }\n\n    if (__peerConnection?.[recipient]) {\n        if (!offer) {\n            await processBuffer(__rtcSdpOfferBuffer, recipient, (offer) => sendAnswer.bind(this)(offer, recipient, socket)); // process all buffered sdp offers\n        }\n        else {\n            await processBuffer(__rtcSdpOfferBuffer, recipient, (offer) => sendAnswer.bind(this)(offer, recipient, socket)); // process all buffered sdp offers first\n            await sendAnswer.bind(this)(offer, recipient, socket);\n        }\n    }\n    else {\n        if (offer) {\n            setBuffer(__rtcSdpOfferBuffer, recipient, offer);\n        }\n    }\n}\n\nexport async function receiveIceCandidate(candidate: any, recipient: string) {\n    this.log('receiveIceCandidate', candidate);\n    if (__peerConnection?.[recipient] && __peerConnection[recipient]?.remoteDescription && __peerConnection[recipient]?.remoteDescription?.type) {\n        if (!candidate) {\n            return processBuffer(__rtcCandidatesBuffer, recipient, (candidate) => __peerConnection[recipient].addIceCandidate(candidate)); // process all buffered candidates\n        }\n        await processBuffer(__rtcCandidatesBuffer, recipient, (candidate) => __peerConnection[recipient].addIceCandidate(candidate)); // process all buffered candidates\n        await __peerConnection[recipient].addIceCandidate(candidate);\n    }\n    else {\n        setBuffer(__rtcCandidatesBuffer, recipient, candidate);\n    }\n}\n\nexport async function closeRTC(params: { cid?: string; close_all?: boolean }): Promise<void> {\n    if (typeof window === 'undefined' || (window as any)._runningInNodeJS) {\n        throw new SkapiError('WebRTC is not supported in Node.js environment.', { code: 'NOT_SUPPORTED' });\n    }\n    validator.Params(params, {\n        cid: v => {\n            if (typeof v !== 'string') {\n                throw new SkapiError(`\"cid\" should be type: <string>.`, { code: 'INVALID_PARAMETER' });\n            }\n            if (v && v.slice(0, 4) !== 'cid:') {\n                throw new SkapiError(`\"cid\" should be a valid connection id.`, { code: 'INVALID_PARAMETER' });\n            }\n            return v;\n        },\n        close: 'boolean'\n    });\n    let socket: WebSocket = await this.__socket;\n    let { cid, close_all = false } = params || {};\n\n    if (!close_all && !cid) {\n        throw new SkapiError(`\"cid\" is required.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    let close = (cid: string) => {\n        if (!cid) {\n            throw new SkapiError(`\"cid\" is required.`, { code: 'INVALID_PARAMETER' });\n        }\n\n        delete __rtcSdpOfferBuffer[cid];\n        delete __rtcCandidatesBuffer[cid];\n\n        // Close all associated data channels\n        if (__dataChannel[cid]) {\n            Object.values(__dataChannel[cid]).forEach(channel => {\n                if (channel.readyState !== 'closed') {\n                    channel.close();\n                }\n            });\n        }\n\n        delete __dataChannel[cid];\n\n        if (__peerConnection?.[cid]) {\n            if (__peerConnection[cid].connectionState !== 'closed') {\n                __peerConnection[cid].close();\n\n                socket.send(JSON.stringify({\n                    action: 'rtc',\n                    uid: cid,\n                    content: { hungup: this.user.user_id },\n                    token: this.session.accessToken.jwtToken\n                }));\n            }\n\n            let msg = {\n                type: 'connectionstatechange',\n                target: __peerConnection[cid],\n                timestamp: new Date().toISOString(),\n                state: __peerConnection[cid].connectionState,\n                iceState: __peerConnection[cid].iceConnectionState,\n                signalingState: __peerConnection[cid].signalingState\n            }\n\n            if (__rtcEvents[cid]) {\n                __rtcEvents[cid](msg);\n            }\n\n            this.log('closeRTC', msg);\n        }\n\n        delete __rtcEvents[cid];\n        delete __receiver_ringing[cid];\n        delete __caller_ringing[cid];\n        delete __peerConnection[cid];\n    }\n\n    if (close_all) {\n        for (let key in __peerConnection) {\n            close(key);\n        }\n    }\n    else {\n        close(cid);\n    }\n\n    this.log('Cleaning up media stream...');\n    if (this.__mediaStream) {\n        this.__mediaStream.getTracks().forEach((track) => {\n            track.stop(); // Stops the track (audio or video)\n        });\n        this.__mediaStream = null; // Clear the reference to the MediaStream\n    }\n}\n\nasync function createMediaStream(media: MediaStream | MediaStreamConstraints): Promise<MediaStream> {\n    if (media instanceof MediaStream) {\n        return media;\n    }\n\n    if (!media.video && !media.audio) {\n        // make dummy media stream\n        // Create a dummy MediaStream\n        const dummyStream = new MediaStream();\n\n        // Create a dummy video track (using a canvas)\n        const canvas = document.createElement('canvas');\n        canvas.width = 1;\n        canvas.height = 1;\n        const dummyVideoStream = canvas.captureStream();\n        const dummyVideoTrack = dummyVideoStream.getVideoTracks()[0];\n\n        // Add the dummy video track to the MediaStream\n        dummyStream.addTrack(dummyVideoTrack);\n\n        // Assign the dummy MediaStream to this.__mediaStream\n        return dummyStream;\n    }\n\n    return window.navigator.mediaDevices.getUserMedia(media);\n}\n\nexport async function connectRTC(\n    params: RTCConnectorParams,\n    callback: (e: RTCEvent) => void\n): Promise<RTCConnector> {\n    if (typeof window === 'undefined' || (window as any)._runningInNodeJS) {\n        throw new SkapiError('WebRTC is not supported in Node.js environment.', { code: 'NOT_SUPPORTED' });\n    }\n    if (typeof callback !== 'function') {\n        throw new SkapiError(`Callback is required.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    if (!this?.session?.accessToken?.jwtToken) {\n        throw new SkapiError('Access token is required.', { code: 'INVALID_PARAMETER' });\n    }\n\n    params = validator.Params(params, {\n        cid: v => {\n            if (typeof v !== 'string') {\n                throw new SkapiError(`\"cid\" should be type: <string>.`, { code: 'INVALID_PARAMETER' });\n            }\n            if (v && v.slice(0, 4) !== 'cid:') {\n                throw new SkapiError(`\"cid\" should be a valid connection id.`, { code: 'INVALID_PARAMETER' });\n            }\n            return v;\n        },\n        ice: ['string', () => 'stun:stun.skapi.com:3468'],\n        media: v => v,\n        channels: ['text-chat', 'file-transfer', 'video-chat', 'voice-chat', 'gaming', {\n            // negotiated: 'boolean',\n            // id: 'number',\n            ordered: 'boolean',\n            maxPacketLifeTime: 'number',\n            maxRetransmits: 'number',\n            protocol: 'string'\n        }, () => {\n            return [{ ordered: true, maxPacketLifeTime: 10, protocol: 'default' }]\n        }]\n    }, ['cid']);\n\n    let { cid, ice } = params;\n\n    if (!(params?.media instanceof MediaStream)) {\n        if (params?.media?.video || params?.media?.audio) {\n            // check if it is localhost or https\n            if (window.location.hostname !== 'localhost' && window.location.protocol !== 'https:') {\n                throw new SkapiError(`Media stream is only supported on either localhost or https.`, { code: 'INVALID_REQUEST' });\n            }\n        }\n    }\n\n    let socket: WebSocket = this.__socket ? await this.__socket : this.__socket;\n\n    if (!socket) {\n        throw new SkapiError(`No realtime connection. Execute connectRealtime() before this method.`, { code: 'INVALID_REQUEST' });\n    }\n\n    if (socket.readyState !== 1) {\n        throw new SkapiError('Realtime connection is not ready.', { code: 'INVALID_REQUEST' });\n    }\n\n    // Call STUN server to get IP address\n    const configuration = {\n        iceServers: [\n            { urls: ice }\n        ]\n    };\n\n    if (!__peerConnection?.[cid]) {\n        __peerConnection[cid] = new RTCPeerConnection(configuration);\n    }\n\n    // add media stream\n    if (params?.media) {\n        this.__mediaStream = await createMediaStream(params.media);\n        this.__mediaStream.getTracks().forEach(track => {\n            __peerConnection[cid].addTrack(track, this.__mediaStream);\n        });\n    }\n\n    __rtcEvents[cid] = callback;\n\n    if (!__dataChannel[cid]) {\n        __dataChannel[cid] = {};\n    }\n\n    for (let i = 0; i < params.channels.length; i++) {\n        let options = params.channels[i];\n\n        if (typeof options === 'string') {\n            switch (options) {\n                case 'text-chat':\n                    options = { ordered: true, maxRetransmits: 10, protocol: 'text-chat' };\n                    break;\n                case 'file-transfer':\n                    options = { ordered: false, maxPacketLifeTime: 3000, protocol: 'file-transfer' };\n                    break;\n                case 'video-chat':\n                    options = { ordered: true, maxRetransmits: 10, protocol: 'video-chat' };\n                    break;\n                case 'voice-chat':\n                    options = { ordered: true, maxRetransmits: 10, protocol: 'voice-chat' };\n                    break;\n                case 'gaming':\n                    options = { ordered: false, maxPacketLifeTime: 100, protocol: 'gaming' };\n                    break;\n                default:\n                    options = { ordered: true, maxRetransmits: 10, protocol: 'default' };\n                    break;\n            }\n        }\n\n        let protocol = options.protocol || 'default';\n        if (Object.keys(__dataChannel[cid]).includes(protocol)) {\n            throw new SkapiError(`Data channel with the protocol \"${protocol}\" already exists.`, { code: 'INVALID_REQUEST' });\n        }\n\n        let dataChannel = __peerConnection[cid].createDataChannel(protocol, options);\n        __dataChannel[cid][protocol] = dataChannel;\n    }\n\n    for (let key in __dataChannel[cid]) {\n        let dataChannel = __dataChannel[cid][key];\n        handleDataChannel.bind(this)(cid, dataChannel);\n    }\n\n    peerConnectionHandler.bind(this)(cid, ['onnegotiationneeded']);\n    await sendOffer.bind(this)(cid);\n\n    return {\n        hangup: () => __caller_ringing[cid] && __caller_ringing[cid](false),\n        connection: new Promise(resolve => {\n            __caller_ringing[cid] = ((proceed: boolean) => {\n                this.log('receiver picked up the call', cid);\n                // proceed\n                if (!proceed) {\n                    closeRTC.bind(this)({ cid: cid });\n                    return null;\n                }\n\n                __peerConnection[cid].onnegotiationneeded = () => {\n                    this.log('onnegotiationneeded', `sending offer to \"${cid}\".`);\n                    sendOffer.bind(this)(cid);\n                    if (__rtcEvents[cid])\n                        __rtcEvents[cid]({\n                            type: 'negotiationneeded',\n                            target: __peerConnection[cid],\n                            timestamp: new Date().toISOString(),\n                            signalingState: __peerConnection[cid].signalingState,\n                            connectionState: __peerConnection[cid].iceConnectionState,\n                            gatheringState: __peerConnection[cid].iceGatheringState\n                        });\n                };\n\n                resolve({\n                    target: __peerConnection[cid],\n                    channels: __dataChannel[cid],\n                    hangup: () => closeRTC.bind(this)({ cid: cid }),\n                    media: this.__mediaStream\n                });\n            }).bind(this);\n        })\n    }\n}\n\nexport function respondRTC(msg: WebSocketMessage): (params: RTCReceiverParams, callback: (e: RTCEvent) => void) => Promise<RTCResolved> {\n    return async (params: RTCReceiverParams, callback: (e: RTCEvent) => void): Promise<RTCResolved> => {\n        params = params || {};\n        params = extractFormData(params).data;\n\n        let sender = msg.sender_cid;\n        let socket: WebSocket = await this.__socket;\n\n        if (!__receiver_ringing[sender]) {\n            return null;\n        }\n\n        if (typeof callback !== 'function') {\n            throw new SkapiError(`Callback is required.`, { code: 'INVALID_PARAMETER' });\n        }\n\n        if (!(params?.media instanceof MediaStream)) {\n            if (params?.media?.video || params?.media?.audio) {\n                // check if it is localhost or https\n                if (window.location.hostname !== 'localhost' && window.location.protocol !== 'https:') {\n                    throw new SkapiError(`Media stream is only supported on either localhost or https.`, { code: 'INVALID_REQUEST' });\n                }\n            }\n        }\n\n        let { ice = 'stun:stun.skapi.com:3468' } = params;\n\n        if (!__peerConnection?.[sender]) {\n            __peerConnection[sender] = new RTCPeerConnection({\n                iceServers: [\n                    { urls: ice }\n                ]\n            });\n        }\n\n        if (params?.media) {\n            this.__mediaStream = await createMediaStream(params.media);\n            this.__mediaStream.getTracks().forEach(track => {\n                __peerConnection[sender].addTrack(track, this.__mediaStream);\n            });\n        }\n\n        delete __receiver_ringing[sender];\n\n        __rtcEvents[sender] = callback;\n\n        if (!__dataChannel[sender]) {\n            __dataChannel[sender] = {};\n        }\n\n        __peerConnection[sender].ondatachannel = (event) => {\n            this.log('ondatachannel', `received data channel \"${event.channel.label}\".`);\n            const dataChannel = event.channel;\n            __dataChannel[sender][dataChannel.label] = dataChannel;\n            handleDataChannel.bind(this)(sender, dataChannel);\n        }\n\n        peerConnectionHandler.bind(this)(sender, ['onnegotiationneeded']);\n        await answerSdpOffer.bind(this)(null, sender);\n        await receiveIceCandidate.bind(this)(null, sender);\n\n        socket.send(JSON.stringify({\n            action: 'rtc',\n            uid: sender,\n            content: { pickup: this.user.user_id },\n            token: this.session.accessToken.jwtToken\n        }));\n\n        return {\n            target: __peerConnection[sender],\n            channels: __dataChannel[sender],\n            hangup: () => closeRTC.bind(this)({ cid: sender }),\n            media: this.__mediaStream\n        }\n    }\n}\n\nasync function sendOffer(recipient) {\n    if (!this?.session?.accessToken?.jwtToken) {\n        throw new SkapiError('Access token is required.', { code: 'INVALID_PARAMETER' });\n    }\n    this.log('sendOffer', recipient);\n    let socket: WebSocket = await this.__socket;\n\n    const offer = await __peerConnection[recipient].createOffer();\n    await __peerConnection[recipient].setLocalDescription(offer);\n\n    let sdpoffer = __peerConnection[recipient].localDescription;\n    this.log('rtcSdpOffer to', sdpoffer);\n\n    socket.send(JSON.stringify({\n        action: 'rtc',\n        uid: recipient,\n        content: { sdpoffer },\n        token: this.session.accessToken.jwtToken\n    }));\n}\n\nasync function sendIceCandidate(event, recipient) {\n    if (!this?.session?.accessToken?.jwtToken) {\n        throw new SkapiError('Access token is required.', { code: 'INVALID_PARAMETER' });\n    }\n    this.log('sendIceCandidate to', recipient);\n\n    let socket: WebSocket = await this.__socket;\n\n    if (!event.candidate) {\n        this.log('candidate-end', 'all ice candidates have been sent');\n        return;\n    }\n\n    let callback = __rtcEvents[recipient] || (() => { });\n\n    // Collect ICE candidates and send them to the remote peer\n    let candidate = event.candidate;\n    this.log('ice gathering state set to', __peerConnection[recipient].iceGatheringState);\n\n    callback({\n        type: 'icecandidate',\n        target: __peerConnection[recipient],\n        timestamp: new Date().toISOString(),\n        candidate: event.candidate.candidate,\n        sdpMid: event.candidate.sdpMid,\n        sdpMLineIndex: event.candidate.sdpMLineIndex,\n        usernameFragment: event.candidate.usernameFragment,\n        protocol: event.candidate.protocol,\n        gatheringState: __peerConnection[recipient].iceGatheringState,\n        connectionState: __peerConnection[recipient].iceConnectionState\n    });\n\n    socket.send(JSON.stringify({\n        action: 'rtc',\n        uid: recipient,\n        content: { candidate },\n        token: this.session.accessToken.jwtToken\n    }));\n}\n\nfunction peerConnectionHandler(key: string, skipKey: string[]) {\n    let skip = new Set(skipKey);\n    let cb = __rtcEvents[key] || ((v: any) => { });\n    let peer = __peerConnection[key];\n\n    const handlers = {\n        ontrack: (event: any) => {\n            cb({\n                type: 'track',\n                target: peer,\n                timeStamp: event.timeStamp,\n                streams: event.streams,\n                track: event.track,\n            });\n        },\n        onicecandidate: (event: RTCPeerConnectionIceEvent) => {\n            sendIceCandidate.bind(this)(event, key);\n            if (event.candidate) {\n                cb({\n                    type: 'icecandidate',\n                    target: peer,\n                    timestamp: new Date().toISOString(),\n                    candidate: event.candidate.candidate,\n                    sdpMid: event.candidate.sdpMid,\n                    sdpMLineIndex: event.candidate.sdpMLineIndex,\n                    usernameFragment: event.candidate.usernameFragment,\n                    protocol: event.candidate.protocol,\n                    gatheringState: peer.iceGatheringState,\n                    connectionState: peer.iceConnectionState\n                });\n            } else {\n                cb({ type: 'icecandidateend', target: peer, timestamp: new Date().toISOString() });\n            }\n        },\n        onicecandidateerror: (event: any) => {\n            cb({\n                type: 'icecandidateerror',\n                target: peer,\n                timestamp: new Date().toISOString(),\n                errorCode: event.errorCode,\n                errorText: event.errorText,\n                url: event.url,\n                hostCandidate: event.hostCandidate,\n                gatheringState: peer.iceGatheringState,\n                connectionState: peer.iceConnectionState\n            });\n        },\n        oniceconnectionstatechange: () => {\n            cb({\n                type: 'iceconnectionstatechange',\n                target: peer,\n                timestamp: new Date().toISOString(),\n                state: peer.iceConnectionState,\n                gatheringState: peer.iceGatheringState,\n                signalingState: peer.signalingState\n            });\n        },\n        onicegatheringstatechange: () => {\n            cb({\n                type: 'icegatheringstatechange',\n                target: peer,\n                timestamp: new Date().toISOString(),\n                state: peer.iceGatheringState,\n                connectionState: peer.iceConnectionState,\n                signalingState: peer.signalingState\n            });\n        },\n        onsignalingstatechange: () => {\n            cb({\n                type: 'signalingstatechange',\n                target: peer,\n                timestamp: new Date().toISOString(),\n                state: peer.signalingState,\n                connectionState: peer.iceConnectionState,\n                gatheringState: peer.iceGatheringState\n            });\n        },\n        onnegotiationneeded: () => {\n            sendOffer.bind(this)(key);\n            cb({\n                type: 'negotiationneeded',\n                target: peer,\n                timestamp: new Date().toISOString(),\n                signalingState: peer.signalingState,\n                connectionState: peer.iceConnectionState,\n                gatheringState: peer.iceGatheringState\n            });\n        },\n        onconnectionstatechange: () => {\n            cb({\n                type: 'connectionstatechange',\n                target: peer,\n                timestamp: new Date().toISOString(),\n                state: peer.connectionState,\n                iceState: peer.iceConnectionState,\n                signalingState: peer.signalingState\n            });\n\n            let state = peer.connectionState;\n            // Clean up on disconnection\n            if (state === 'disconnected' || state === 'failed' || state === 'closed') {\n                // Close all associated data channels\n                closeRTC.bind(this)({ cid: key });\n            }\n        }\n    };\n\n    for (const [event, handler] of Object.entries(handlers)) {\n        if (!skip.has(event)) {\n            peer[event] = handler;\n        }\n    }\n}\n\nfunction handleDataChannel(key: string, dataChannel: RTCDataChannel, skipKey?: string[]) {\n    let skip = new Set(skipKey);\n    let cb = __rtcEvents[key] || ((v: any) => { });\n\n    const events = {\n        onmessage: (event) => {\n            let msg = {\n                type: event.type,\n                target: dataChannel,\n                timeStamp: event.timeStamp,\n                data: event.data,\n                lastEventId: event.lastEventId,\n                origin: event.origin,\n                readyState: dataChannel.readyState,\n                bufferedAmount: dataChannel.bufferedAmount\n            };\n            this.log(`${dataChannel.label}: message`, event.data);\n            cb(msg);\n        },\n        onerror: (event) => {\n            let err = {\n                type: event.type,\n                target: dataChannel,\n                timeStamp: event.timeStamp,\n                error: event.error.message,\n                errorCode: event.error.errorDetail,\n                readyState: dataChannel.readyState,\n                label: dataChannel.label\n            };\n            this.log(`${dataChannel.label}: error`, event.error.message);\n            cb(err);\n        },\n        onclose: (event) => {\n            let closed = {\n                type: event.type,\n                target: dataChannel,\n                timeStamp: event.timeStamp,\n                readyState: dataChannel.readyState,\n                label: dataChannel.label,\n                id: dataChannel.id\n            };\n            this.log(`${dataChannel.label}: closed`, null);\n            cb(closed);\n\n            if (__dataChannel[key]) {\n                delete __dataChannel[key][dataChannel.label];\n                if (Object.keys(__dataChannel[key]).length === 0) {\n                    closeRTC.bind(this)({ cid: key });\n                }\n            }\n        },\n        onbufferedamountlow: (event) => {\n            let buffer = {\n                target: dataChannel,\n                bufferedAmount: dataChannel.bufferedAmount,\n                bufferedAmountLowThreshold: dataChannel.bufferedAmountLowThreshold,\n                type: event.type,\n                timeStamp: event.timeStamp\n            };\n            this.log(`${dataChannel.label}: bufferedamountlow`, dataChannel.bufferedAmount);\n            cb(buffer);\n        },\n        onopen: (event) => {\n            this.log('dataChannel', `data channel: \"${dataChannel.label}\" is open and ready to send messages.`);\n            let msg = {\n                type: event.type,\n                target: dataChannel,\n                timeStamp: event.timeStamp,\n                readyState: dataChannel.readyState,\n                label: dataChannel.label,\n                id: dataChannel.id,\n                ordered: dataChannel.ordered,\n                maxRetransmits: dataChannel.maxRetransmits,\n                protocol: dataChannel.protocol\n            };\n            cb(msg);\n        }\n    };\n\n    for (const [event, handler] of Object.entries(events)) {\n        if (!skip.has(event)) {\n            dataChannel[event] = handler;\n        }\n    }\n}\n\n\n","\nimport SkapiError from '../main/error';\nimport validator from '../utils/validator';\nimport { extractFormData } from '../utils/utils';\nimport { request } from '../utils/network';\nimport { DatabaseResponse, FetchOptions, RealtimeCallback, WebSocketMessage } from '../Types';\nimport { answerSdpOffer, receiveIceCandidate, __peerConnection, __receiver_ringing, closeRTC, respondRTC, __caller_ringing, __rtcEvents } from './webrtc';\nimport { getJwtToken } from './user';\n\n// let __roomList: {\n//     [realTimeGroup: string]: {\n//         [sender_id: string]: string[]; // connection id, (single person can have multiple connection id)\n//     }\n// } = {};\n\nlet __current_socket_room: string;\nlet __keepAliveInterval = null;\nlet closedByIntention = true;\nlet reconnectAttempts = 0;\n\nasync function prepareWebsocket() {\n    if (typeof window === 'undefined' || (window as any)._runningInNodeJS) {\n        throw new SkapiError('WebSocket is not supported in Node.js environment.', { code: 'NOT_SUPPORTED' });\n    }\n\n    // Connect to the WebSocket server\n    await this.getProfile();\n\n    if (!this.session) {\n        throw new SkapiError(`No access.`, { code: 'INVALID_REQUEST' });\n    }\n\n    let r = await this.record_endpoint;\n\n    return new WebSocket(\n        r.websocket_private + '?token=' + this.session.accessToken.jwtToken\n    );\n}\n\n\nlet visibilitychange = null;\n\nexport async function closeRealtime(): Promise<void> {\n    if (typeof window === 'undefined' || (window as any)._runningInNodeJS) {\n        throw new SkapiError('WebSocket is not supported in Node.js environment.', { code: 'NOT_SUPPORTED' });\n    }\n    closedByIntention = true;\n    let socket: WebSocket = this.__socket ? await this.__socket : this.__socket;\n    closeRTC.bind(this)({ close_all: true });\n\n    if (__current_socket_room) {\n        joinRealtime.bind(this)({ group: null });\n    }\n\n    // __roomList = {};\n    reconnectAttempts = 0;\n\n    if (__keepAliveInterval) {\n        __keepAliveInterval.terminate();\n        __keepAliveInterval = null;\n    }\n\n    try {\n        if (socket) {\n            socket.close();\n        }\n    }\n    catch (e) { }\n\n    window.removeEventListener('visibilitychange', visibilitychange);\n    this.__socket = null;\n    return null;\n}\n\nexport async function connectRealtime(cb: RealtimeCallback, delay = 50, reconnect?: string): Promise<WebSocket> {\n    if (typeof window === 'undefined' || (window as any)._runningInNodeJS) {\n        throw new SkapiError('WebSocket is not supported in Node.js environment.', { code: 'NOT_SUPPORTED' });\n    }\n    if (typeof cb !== 'function') {\n        throw new SkapiError(`Callback must be a function.`, { code: 'INVALID_REQUEST' });\n    }\n\n    if (reconnect === 'reconnect') {\n        if (this.__socket instanceof Promise) {\n            let socket = await this.__socket;\n            if (socket.readyState !== WebSocket.CLOSED && socket.readyState !== WebSocket.CLOSING) {\n                return this.__socket;\n            }\n        }\n    }\n\n    else if (closedByIntention) {\n        // if the connection was closed intentionally, and it's not a reconnect attempt\n        visibilitychange = () => {\n            if (!document.hidden && !closedByIntention) {\n                connectRealtime.bind(this)(cb, 0, 'reconnect');\n            }\n        }\n\n        if (this.__socket instanceof Promise) {\n            return this.__socket;\n        }\n    }\n\n    if (__keepAliveInterval) {\n        __keepAliveInterval.terminate();\n        __keepAliveInterval = null;\n    }\n\n    this.__socket = new Promise(async (resolve) => {\n        await getJwtToken.bind(this)();\n\n        setTimeout(async () => {\n            let socket: WebSocket = await prepareWebsocket.bind(this)();\n\n            socket.onopen = () => {\n                closedByIntention = false;\n                reconnectAttempts = 0;\n\n                if (reconnect !== 'reconnect') {\n                    window.addEventListener('visibilitychange', visibilitychange);\n                }\n\n                this.log('realtime onopen', 'Connected to WebSocket server.');\n                cb({ type: 'success', message: 'Connected to WebSocket server.' });\n\n                if (__current_socket_room) {\n                    socket.send(JSON.stringify({\n                        action: 'joinRoom',\n                        rid: __current_socket_room,\n                        token: this.session.accessToken.jwtToken\n                    }));\n                }\n\n                // // keep alive\n\n                // Define worker script as a string\n                const workerScript = /*js*/`\n                    let interval = 15000; // Set interval time 15 seconds\n\n                    function runInterval() {\n                        postMessage({ type: \"ping\" });\n                        setTimeout(runInterval, interval); // Use setTimeout instead of setInterval\n                    }\n\n                    runInterval(); // Start interval\n                `;\n\n                // Create a Blob URL for the worker\n                const blob = new Blob([workerScript], { type: \"application/javascript\" });\n                __keepAliveInterval = new Worker(URL.createObjectURL(blob));\n\n                // Listen for messages from the worker\n                __keepAliveInterval.onmessage = (event) => {\n                    if (socket.readyState === 1) {\n                        socket.send(JSON.stringify({\n                            action: 'keepAlive'\n                        }));\n                    }\n                };\n\n                resolve(socket);\n            };\n\n            socket.onmessage = async (event) => {\n                let data = ''\n\n                try {\n                    data = JSON.parse(decodeURI(event.data));\n                    this.log('socket onmessage', data);\n                }\n                catch (e) {\n                    return;\n                }\n\n                let type;\n                switch (true) {\n                    case !!data?.['#message']:\n                        type = 'message';\n                        break;\n                    case !!data?.['#private']:\n                        type = 'private';\n                        break;\n                    case !!data?.['#notice']:\n                        type = 'notice';\n                        break;\n                    case !!data?.['#rtc']:\n                        type = 'rtc';\n                        break;\n                    case !!data?.['#error']:\n                        type = 'error';\n                        break;\n                }\n\n                if (!type) {\n                    return;\n                }\n\n                let msg: WebSocketMessage = {\n                    type,\n                    message: data?.['#rtc'] || data?.['#message'] || data?.['#private'] || data?.['#notice'] || data?.['#error'] || null,\n                    sender: data?.['#user_id'] || null,\n                    sender_cid: !!data?.['#scid'] ? \"cid:\" + data['#scid'] : null,\n                    sender_rid: data?.['#srid'] || null,\n                    code: data?.['#code'] || null\n                };\n\n                if (type === 'notice') {\n                    // if (__current_socket_room && (msg.code === 'USER_LEFT' || msg.code === 'USER_DISCONNECTED')) {\n                    //     let user_id = msg.sender;\n                    //     if (__roomList?.[__current_socket_room]?.[user_id]) {\n                    //         __roomList[__current_socket_room][user_id] = __roomList[__current_socket_room][user_id].filter(v => v !== msg.sender_cid);\n                    //     }\n\n                    //     if (__roomList?.[__current_socket_room]?.[user_id] && __roomList[__current_socket_room][user_id].length === 0) {\n                    //         delete __roomList[__current_socket_room][user_id];\n                    //     }\n\n                    //     if (__roomList?.[__current_socket_room]?.[user_id]) {\n                    //         // user is still in the group don't call the callback\n                    //         return\n                    //     }\n                    // }\n                    // else if (__current_socket_room && msg.code === 'USER_JOINED') {\n                    //     let user_id = msg.sender;\n                    //     if (!__roomList?.[__current_socket_room]) {\n                    //         __roomList[__current_socket_room] = {};\n                    //     }\n                    //     if (!__roomList[__current_socket_room][user_id]) {\n                    //         __roomList[__current_socket_room][user_id] = [msg.sender_cid];\n                    //     }\n                    //     else {\n                    //         if (!__roomList[__current_socket_room][user_id].includes(msg.sender_cid)) {\n                    //             __roomList[__current_socket_room][user_id].push(msg.sender_cid);\n                    //         }\n                    //         return;\n                    //     }\n                    // }\n                    cb(msg);\n                }\n                else if (type === 'rtc') {\n                    // rtc signaling\n                    if (msg.sender !== this.user.user_id) {\n                        let rtc = msg.message;\n                        if (rtc.hungup) {\n                            // otherside has hung up the call\n                            if (__caller_ringing[msg.sender_cid]) {\n                                __caller_ringing[msg.sender_cid](false);\n                                delete __caller_ringing[msg.sender_cid];\n                            }\n                            if (__receiver_ringing[msg.sender_cid]) {\n                                delete __receiver_ringing[msg.sender_cid];\n                            }\n                            if (__peerConnection?.[msg.sender_cid]) {\n                                closeRTC.bind(this)({ cid: msg.sender_cid });\n                            }\n                            msg.type = 'rtc:closed';\n                            cb(msg);\n                            return;\n                        }\n                        if (rtc.candidate) {\n                            receiveIceCandidate.bind(this)(rtc.candidate, msg.sender_cid);\n                        }\n                        if (rtc.sdpoffer) {\n                            answerSdpOffer.bind(this)(rtc.sdpoffer, msg.sender_cid);\n                            if (!__receiver_ringing[msg.sender_cid]) {\n                                __receiver_ringing[msg.sender_cid] = msg.sender_cid;\n                                delete msg.message;\n\n                                msg.connectRTC = respondRTC.bind(this)(msg);\n                                msg.type = 'rtc:incoming';\n                                msg.hangup = (() => {\n                                    if (__peerConnection[msg.sender_cid]) {\n                                        closeRTC.bind(this)({ cid: msg.sender_cid });\n                                    }\n                                    else if (__receiver_ringing[msg.sender_cid]) {\n                                        delete __receiver_ringing[msg.sender_cid];\n                                        socket.send(JSON.stringify({\n                                            action: 'rtc',\n                                            uid: msg.sender_cid,\n                                            content: { hungup: this.user.user_id },\n                                            token: this.session.accessToken.jwtToken\n                                        }));\n                                    }\n                                }).bind(this);\n\n                                cb(msg);\n                            }\n                        }\n                        if (rtc.pickup) {\n                            // receiver has answered the call\n                            if (__caller_ringing[msg.sender_cid]) {\n                                __caller_ringing[msg.sender_cid](true);\n                                delete __caller_ringing[msg.sender_cid];\n                            }\n                        }\n                        if (rtc.sdpanswer) {\n                            if (__peerConnection[msg.sender_cid]) {\n                                // receive answer from the receiver\n                                if (__peerConnection[msg.sender_cid].signalingState === 'have-local-offer') {\n                                    await __peerConnection[msg.sender_cid].setRemoteDescription(new RTCSessionDescription(rtc.sdpanswer));\n                                }\n                                else {\n                                    throw new SkapiError(`Invalid signaling state.`, { code: 'INVALID_REQUEST' });\n                                }\n                            }\n                        }\n                    }\n                }\n                else {\n                    cb(msg);\n                }\n            };\n\n            socket.onclose = () => {\n                if (closedByIntention) {\n                    this.log('realtime onclose', 'WebSocket connection closed.');\n                    cb({ type: 'close', message: 'WebSocket connection closed.' });\n                }\n                else {\n                    this.log('realtime onclose', 'WebSocket unexpected close.');\n                    cb({ type: 'error', message: 'Skapi: WebSocket unexpected close.' });\n\n                    reconnectAttempts++;\n                    if (reconnectAttempts < 3) {\n                        this.log('realtime onclose', 'Reconnecting to WebSocket server...' + reconnectAttempts);\n                        cb({ type: 'reconnect', message: 'Reconnecting to WebSocket server...' + reconnectAttempts });\n                        connectRealtime.bind(this)(cb, 3000, 'reconnect');\n                    }\n                    else {\n                        this.log('realtime onclose', 'Max reconnection attempts reached.');\n                        cb({ type: 'error', message: 'Skapi: Max reconnection attempts reached.' });\n                    }\n                }\n            };\n\n            socket.onerror = () => {\n                this.log('realtime onerror', 'WebSocket connection error.');\n                cb({ type: 'error', message: 'Skapi: WebSocket connection error.' });\n            };\n        }, delay);\n    });\n}\n\n\nexport async function postRealtime(message: any, recipient: string, notification?: { config?: { always: boolean; }; title: string; body: string; }): Promise<{ type: 'success', message: 'Message sent.' }> {\n    if (typeof window === 'undefined' || (window as any)._runningInNodeJS) {\n        throw new SkapiError('WebSocket is not supported in Node.js environment.', { code: 'NOT_SUPPORTED' });\n    }\n    let socket: WebSocket = this.__socket ? await this.__socket : this.__socket;\n\n    if (!socket) {\n        throw new SkapiError(`No realtime connection. Execute connectRealtime() before this method.`, { code: 'INVALID_REQUEST' });\n    }\n\n    if (!recipient) {\n        throw new SkapiError(`No recipient.`, { code: 'INVALID_REQUEST' });\n    }\n\n    await getJwtToken.bind(this)();\n\n    message = extractFormData(message).data;\n\n    let notificationStr = '';\n    if (notification) {\n        notification = validator.Params(\n            notification,\n            {\n                config: {\n                    always: 'boolean'\n                },\n                title: 'string',\n                body: 'string'\n            },\n            ['title', 'body']\n        );\n        // stringify notification and check if size exceeds 3kb\n        notificationStr = JSON.stringify({ title: notification.title, body: notification.body });\n        let notificationSize = new Blob([notificationStr]).size;\n        if (notificationSize > 3072) {\n            throw new SkapiError(`Notification size exceeds 3kb.`, { code: 'INVALID_PARAMETER' });\n        }\n    }\n\n    if (socket.readyState === 1) {\n        try {\n            validator.UserId(recipient);\n            socket.send(JSON.stringify({\n                action: 'sendMessage',\n                uid: recipient,\n                content: message,\n                notification: notificationStr,\n                notificationConfig: notification?.config || {},\n                // token: this.session.accessToken.jwtToken\n                token: `IdT:${this.service}:${this.owner}:` + (this.bearerToken || this.session?.idToken?.jwtToken || 'null')\n            }));\n\n        } catch (err) {\n            this.log('postRealtime:err', { err });\n            if (__current_socket_room !== recipient) {\n                throw new SkapiError(`User has not joined to the recipient group. Run joinRealtime({ group: \"${recipient}\" })`, { code: 'INVALID_REQUEST' });\n            }\n\n            socket.send(JSON.stringify({\n                action: 'broadcast',\n                rid: recipient,\n                content: message,\n                notification: notificationStr,\n                notificationConfig: notification?.config || {},\n                // token: this.session.accessToken.jwtToken,\n                token: `IdT:${this.service}:${this.owner}:` + (this.bearerToken || this.session?.idToken?.jwtToken || 'null')\n            }));\n        }\n\n        return { type: 'success', message: 'Message sent.' };\n    }\n\n    throw new SkapiError('Realtime connection is not open. Try reconnecting with connectRealtime().', { code: 'INVALID_REQUEST' });\n}\n\nexport async function joinRealtime(params: { group?: string | null }): Promise<{ type: 'success', message: string }> {\n    if (typeof window === 'undefined' || (window as any)._runningInNodeJS) {\n        throw new SkapiError('WebSocket is not supported in Node.js environment.', { code: 'NOT_SUPPORTED' });\n    }\n    let socket: WebSocket = this.__socket ? await this.__socket : this.__socket;\n\n    if (!socket) {\n        throw new SkapiError(`No realtime connection. Execute connectRealtime() before this method.`, { code: 'INVALID_REQUEST' });\n    }\n\n    await getJwtToken.bind(this)();\n    params = extractFormData(params, { nullIfEmpty: true }).data;\n\n    let { group = null } = params;\n    if (!group && !__current_socket_room) {\n        return { type: 'success', message: 'Left realtime message group.' }\n    }\n\n    if (group !== null && typeof group !== 'string') {\n        throw new SkapiError(`\"group\" must be a string | null.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    socket.send(JSON.stringify({\n        action: 'joinRoom',\n        rid: group,\n        token: this.session.accessToken.jwtToken\n    }));\n\n    __current_socket_room = group;\n\n    return { type: 'success', message: group ? `Joined realtime message group: \"${group}\".` : 'Left realtime message group.' }\n}\n\nexport async function getRealtimeUsers(params: { group: string, user_id?: string }, fetchOptions?: FetchOptions): Promise<DatabaseResponse<{ user_id: string; cid: string }[]>> {\n    params = validator.Params(\n        params,\n        {\n            user_id: (v: string) => validator.UserId(v, 'User ID in \"user_id\"'),\n            group: ['string', () => {\n                if (!__current_socket_room) {\n                    throw new SkapiError(`No group has been joined. Otherwise \"group\" is required.`, { code: 'INVALID_REQUEST' });\n                }\n                return __current_socket_room;\n            }]\n        }\n    );\n\n    let res = await request.bind(this)(\n        'get-ws-group',\n        params,\n        {\n            fetchOptions,\n            auth: true,\n            method: 'post'\n        }\n    );\n\n    res.list = res.list.map((v: any) => {\n        let user_id = v.uid.split('#')[1];\n        // if (!params.user_id) {\n        //     if (!__roomList[params.group]) {\n        //         __roomList[params.group] = {};\n        //     }\n        //     if (!__roomList[params.group][user_id]) {\n        //         __roomList[params.group][user_id] = [v.cid];\n        //     }\n        //     else if (!__roomList[params.group][user_id].includes(v.cid)) {\n        //         __roomList[params.group][user_id].push(v.cid);\n        //     }\n        // }\n\n        return {\n            user_id,\n            cid: \"cid:\" + v.cid\n        }\n    });\n\n    return res;\n}\n\nexport async function getRealtimeGroups(\n    params?: {\n        /** Index name to search. */\n        searchFor: 'group' | 'number_of_users';\n        /** Index value to search. */\n        value?: string | number;\n        /** Search condition. */\n        condition?: '>' | '>=' | '=' | '<' | '<=' | '!=' | 'gt' | 'gte' | 'eq' | 'lt' | 'lte' | 'ne';\n        /** Range of search. */\n        range?: string | number;\n    } | null,\n    fetchOptions?: FetchOptions\n): Promise<DatabaseResponse<{ group: string; number_of_users: number; }>> {\n    await this.__connection;\n\n    if (!params) {\n        params = { searchFor: 'group', value: ' ', condition: '>' };\n    }\n\n    params = validator.Params(\n        params,\n        {\n            searchFor: ['group', 'number_of_users', () => 'group'],\n            value: ['string', 'number', () => {\n                if (params?.searchFor && params?.searchFor === 'number_of_users') {\n                    return 0;\n                }\n\n                return ' ';\n            }],\n            condition: ['>', '>=', '=', '<', '<=', '!=', 'gt', 'gte', 'eq', 'lt', 'lte', 'ne'],\n            range: ['string', 'number']\n        }\n    );\n\n    if (!params.condition) {\n        if (params.value === ' ' || !params.value) {\n            params.condition = '>';\n        }\n        else {\n            params.condition = '=';\n        }\n    }\n\n    if (params.range && params.condition) {\n        delete params.condition;\n    }\n\n    if (params.searchFor === 'number_of_users' && typeof params.value !== 'number') {\n        throw new SkapiError(`\"value\" must be a number.`, { code: 'INVALID_PARAMETER' });\n    }\n    if (params.searchFor === 'group' && typeof params.value !== 'string') {\n        throw new SkapiError(`\"value\" must be a string.`, { code: 'INVALID_PARAMETER' });\n    }\n    if (params.hasOwnProperty('range') && typeof params.range !== typeof params.value) {\n        throw new SkapiError(`\"range\" must be a ${typeof params.value}.`, { code: 'INVALID_PARAMETER' });\n    }\n\n    let res = await request.bind(this)(\n        'get-ws-group',\n        params,\n        {\n            fetchOptions,\n            auth: true,\n            method: 'post'\n        }\n    )\n\n    res.list = res.list.map((v: any) => {\n        return {\n            group: v.rid.split('#')[1],\n            number_of_users: v.cnt\n        }\n    });\n\n    return res;\n}","import {\n    Form,\n    ProgressCallback\n} from '../Types';\nimport SkapiError from '../main/error';\nimport validator from '../utils/validator';\nimport { request } from '../utils/network';\nimport { extractFormData } from '../utils/utils';\n\nconst hasFormData = typeof FormData !== 'undefined';\nconst hasHTMLFormElement = typeof HTMLFormElement !== 'undefined';\nconst hasSubmitEvent = typeof SubmitEvent !== 'undefined';\n\nexport async function clientSecretRequest(params: {\n    url: string;\n    clientSecretName: string;\n    method: 'GET' | 'POST' | 'DELETE' | 'PUT';\n    headers?: { [key: string]: string };\n    data?: { [key: string]: any };\n    params?: { [key: string]: string };\n}) {\n    let hasSecret = false;\n\n    let checkClientSecretPlaceholder = (v: any) => {\n        for (let k in v) {\n            if (typeof v[k] === 'string' && v[k].includes('$CLIENT_SECRET')) {\n                hasSecret = true;\n                break;\n            }\n        }\n    }\n\n    params = validator.Params(params, {\n        url: (v: string) => {\n            if (!v || typeof v !== 'string') {\n                throw new SkapiError('\"url\" should be type: <string>.', { code: 'INVALID_PARAMETER' });\n            }\n            validator.Url(v);\n            if (v.includes('$CLIENT_SECRET')) {\n                hasSecret = true;\n            }\n            return v;\n        },\n        clientSecretName: 'string',\n        method: (v: string) => {\n            if (v && typeof v !== 'string') {\n                throw new SkapiError('\"method\" should be either \"GET\" or \"POST\" or \"DELETE\" or \"PUT\".', { code: 'INVALID_PARAMETER' });\n            }\n            let lo = v.toLowerCase();\n            if (lo !== 'get' && lo !== 'post' && lo !== 'delete' && lo !== 'put') {\n                throw new SkapiError('\"method\" should be either \"GET\" or \"POST\" or \"DELETE\" or \"PUT\".', { code: 'INVALID_PARAMETER' });\n            }\n            return lo;\n        },\n        headers: (v: any) => {\n            if (v && typeof v !== 'object') {\n                throw new SkapiError('\"headers\" should be type: <object>.', { code: 'INVALID_PARAMETER' });\n            }\n            checkClientSecretPlaceholder(v);\n            return v;\n        },\n        data: (v: any) => {\n            if (v && typeof v !== 'object') {\n                throw new SkapiError('\"data\" should be type: <object>.', { code: 'INVALID_PARAMETER' });\n            }\n            checkClientSecretPlaceholder(v);\n            return v;\n        },\n        params: (v: any) => {\n            if (v && typeof v !== 'object') {\n                throw new SkapiError('\"params\" should be type: <object>.', { code: 'INVALID_PARAMETER' });\n            }\n            checkClientSecretPlaceholder(v);\n            return v;\n        }\n    }, ['clientSecretName', 'method', 'url']);\n\n    if (!hasSecret) {\n        throw new SkapiError(`At least one parameter value should include \"$CLIENT_SECRET\" in ${params.method.toLowerCase() === 'post' ? '\"data\"' : '\"params\"'} or \"headers\".`, { code: 'INVALID_PARAMETER' });\n    }\n\n    await this.__connection;\n    let auth = !!this.__user;\n\n    return request.bind(this)(\"csr\", params, { auth });\n}\n\nexport async function sendInquiry(data: Form<{\n    name: string;\n    email: string;\n    subject: string;\n    message: string;\n}>): Promise<\"SUCCESS: Inquiry has been sent.\"> {\n    await this.__connection;\n\n    let params = {\n        name: 'string',\n        email: v => {\n            validator.Email(v);\n            return v;\n        },\n        subject: 'string',\n        message: 'string'\n    }\n\n    data = validator.Params(data, params, [\n        'name',\n        'email',\n        'subject',\n        'message'\n    ]);\n\n    await request.bind(this)('send-inquiry', data);\n\n    return 'SUCCESS: Inquiry has been sent.';\n}\n\nexport async function secureRequest<RequestParams = {\n    /** Request url */\n    url: string;\n    /** Request data */\n    data?: any;\n    /** requests are sync when true */\n    sync?: boolean;\n}, Response = { response: any; statusCode: number; url: string; }>(params: RequestParams[] | Form<RequestParams>, url?: string): Promise<Response | Response[]> {\n    await this.__connection;\n\n    if ((hasFormData && params instanceof FormData) || (hasHTMLFormElement && params instanceof HTMLFormElement) || (hasSubmitEvent && params instanceof SubmitEvent)) {\n        if (!url) {\n            throw new SkapiError('Url string as a second argument is required when form is passed.', { code: 'INVALID_PARAMETER' });\n        }\n\n        let formData = extractFormData(params);\n\n        params = {\n            url,\n            data: formData.data,\n            sync: true\n        } as Form<RequestParams>\n    }\n\n    let paramsStruct = {\n        url: (v: string) => {\n            return validator.Url(v);\n        },\n        data: v => v,\n        sync: ['boolean', () => true]\n    };\n\n    if (Array.isArray(params)) {\n        for (let r of params) {\n            r = validator.Params(r, paramsStruct);\n        }\n    }\n\n    else {\n        params = validator.Params(params, paramsStruct);\n    }\n\n    return request.bind(this)('post-secure', params, { auth: true });\n};\n\nexport async function mock(\n    data: Form<{ [key: string]: any } & { raise?: 'ERR_INVALID_REQUEST' | 'ERR_INVALID_PARAMETER' | 'SOMETHING_WENT_WRONG' | 'ERR_EXISTS' | 'ERR_NOT_EXISTS'; }>,\n    options?: {\n        auth?: boolean;\n        method?: string;\n        responseType?: 'blob' | 'json' | 'text' | 'arrayBuffer' | 'formData' | 'document';\n        contentType?: string;\n        progress?: ProgressCallback;\n    }): Promise<{ [key:string]:any; }> {\n    await this.__connection;\n    let { auth = false, method = 'POST', bypassAwaitConnection = false, responseType, contentType, progress } = (options as any) || {};\n\n    options = Object.assign(\n        { auth, method, bypassAwaitConnection, responseType, contentType },\n        {\n            fetchOptions: { progress }\n        }\n    );\n\n    if (typeof data !== 'object' && (contentType === 'application/json' || contentType === undefined)) {\n        throw new SkapiError('\"data\" should be type: <object>.', { code: 'INVALID_PARAMETER' });\n    }\n\n    return request.bind(this)('mock', data, options);\n};\n","import {\n    DatabaseResponse,\n    FetchOptions,\n    Form,\n    Newsletter,\n    Subscription,\n    RecordData\n} from '../Types';\nimport SkapiError from '../main/error';\nimport validator from '../utils/validator';\nimport { request } from '../utils/network';\nimport { checkAdmin } from './user';\nimport { normalizeRecord } from './database';\nimport { extractFormData } from '../utils/utils';\n\nexport async function getFeed(params?: { access_group?: number; }, fetchOptions?: FetchOptions): Promise<DatabaseResponse<RecordData>> {\n    await this.__connection;\n\n    params = validator.Params(\n        params || {},\n        {\n            access_group: v => {\n                if(v === 'authorized') {\n                    v = 1;\n                }\n                if(v === 'public') {\n                    v = 0;\n                }\n                if (typeof v !== 'number') {\n                    throw new SkapiError('\"access_group\" should be type number.', { code: 'INVALID_PARAMETER' });\n                }\n                if (v < 0) {\n                    throw new SkapiError('\"access_group\" should be zero or a positive number.', { code: 'INVALID_PARAMETER' });\n                }\n                if(v > this.__user.access_group) {\n                    throw new SkapiError('User has no access.', { code: 'INVALID_REQUEST' });\n                }\n                return v;\n            }\n        }\n    );\n    let recs = await request.bind(this)('get-feed', params, { auth: true, fetchOptions });\n    for (let i in recs.list) {\n        recs.list[i] = await normalizeRecord.bind(this)(recs.list[i]);\n    }\n    return recs;\n}\n\nfunction cannotBeSelfId(v) {\n    if (v === this.__user.user_id) {\n        throw new SkapiError(`\"user_id\" cannot be the user's own ID.`, { code: 'INVALID_PARAMETER' });\n    }\n    return validator.UserId(v, '\"user_id\"');\n}\n\nexport async function getSubscriptions(\n    params: {\n        /** Subscribers user id. */\n        subscriber?: string;\n        /** User ID of the subscription. User id that subscriber has subscribed to. */\n        subscription?: string;\n        /** Fetch blocked subscription when True */\n        blocked?: boolean;\n    },\n    fetchOptions?: FetchOptions,\n): Promise<DatabaseResponse<Subscription>> {\n    params = extractFormData(params, { ignoreEmpty: true }).data as any;\n    params = validator.Params(params, {\n        subscriber: (v: string) => validator.UserId(v, 'User ID in \"subscriber\"'),\n        subscription: cannotBeSelfId.bind(this),\n        blocked: 'boolean'\n    });\n\n    if (!params.subscriber && !params.subscription) {\n        throw new SkapiError('At least either \"subscriber\" or \"subscription\" should have a value.', { code: 'INVALID_PARAMETER' });\n    }\n\n    let response = await request.bind(this)('get-subscription', params, Object.assign({ auth: true }, { fetchOptions }));\n\n    response.list = response.list.map(((s: Record<string, any>) => {\n        let subscription: Record<string, any> = {};\n        if(s.sub) {\n            let subSplit = s.sub.split('#');\n            subscription.subscriber = subSplit[2];\n            subscription.subscription = subSplit[0];\n        }\n        else {\n            subscription.subscriber = s.subscriber;\n            subscription.subscription = s.subscription;\n        }\n        subscription.timestamp = s?.timestamp || s.stmp;\n        subscription.blocked = s?.blocked || s.grp.substring(0, 1) === 'N';\n        Object.assign(subscription, s.opt);\n        return subscription;\n    }));\n\n    return response;\n}\n\nexport async function subscribe(params: { user_id: string; get_feed?: boolean; get_notified?: boolean; get_email?: boolean; }): Promise<Subscription> {\n    await this.__connection;\n    params = validator.Params(params, {\n        user_id: cannotBeSelfId.bind(this),\n        get_feed: ['boolean', ()=>false],\n        get_notified: ['boolean', ()=>false],\n        get_email: v => {\n            if (v && !this.__user.email || !this.__user.email_verified) {\n                throw new SkapiError('User has no verified email address.', { code: 'INVALID_REQUEST' });\n            }\n            return !!v;\n        }\n    }, ['user_id']);\n\n    let s = await request.bind(this)('subscription', {\n        subscribe: params.user_id,\n        option: {\n            get_feed: params.get_feed,\n            get_notified: params.get_notified,\n            get_email: params.get_email || false\n        }\n    }, { auth: true });\n\n    let subscription:any = {};\n    if(s.sub) {\n        let subSplit = s.sub.split('#');\n        subscription.subscriber = subSplit[2];\n        subscription.subscription = subSplit[0];\n    }\n    else {\n        subscription.subscriber = s.subscriber;\n        subscription.subscription = s.subscription;\n    }\n    subscription.timestamp = s?.timestamp || s.stmp;\n    subscription.blocked = s?.blocked || s.grp.substring(0, 1) === 'N';\n    Object.assign(subscription, s.opt);\n    return subscription;\n}\n\nexport async function unsubscribe(params: { user_id: string; }): Promise<'SUCCESS: The user has unsubscribed.'> {\n    await this.__connection;\n    let { user_id } = validator.Params(params, {\n        user_id: cannotBeSelfId.bind(this),\n    }, ['user_id']);\n\n    return await request.bind(this)('subscription', {\n        unsubscribe: user_id,\n    }, { auth: true });\n}\n\nexport async function blockSubscriber(params: { user_id: string; }): Promise<'SUCCESS: Blocked user ID \"xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx\".'> {\n    await this.__connection;\n    let { user_id } = validator.Params(params, {\n        user_id: cannotBeSelfId.bind(this),\n    }, ['user_id']);\n    return await request.bind(this)('subscription', { block: user_id }, { auth: true });\n}\n\nexport async function unblockSubscriber(params: { user_id: string; }): Promise<'SUCCESS: Unblocked user ID \"xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx\".'> {\n    await this.__connection;\n    let { user_id } = validator.Params(params, {\n        user_id: cannotBeSelfId.bind(this),\n    }, ['user_id']);\n    return await request.bind(this)('subscription', { unblock: user_id }, { auth: true });\n}\n\n// requires auth\nexport async function getNewsletterSubscription(params: {group?: number | 'public' | 'authorized';},\nfetchOptions?: FetchOptions): Promise<{\n    active: boolean;\n    timestamp: number;\n    group: number;\n    subscribed_email: string;\n}[]> {\n    await this.__connection;\n    let isAdmin = await checkAdmin.bind(this)();\n\n    params = validator.Params(\n        params,\n        {\n            user_id: v => {\n                if (v !== this.__user.user_id && !isAdmin) {\n                    throw new SkapiError(`No access.`, { code: 'INVALID_REQUEST' });\n                }\n\n                return v;\n            },\n            group: v => {\n                if (v === 'public') {\n                    v = 0\n                }\n                if (v === 'authorized') {\n                    v = 1;\n                }\n                if (typeof v !== 'number') {\n                    throw new SkapiError('\"group\" should be type number | \"public\" | \"authorized\".', { code: 'INVALID_PARAMETER' })\n                }\n                return v;\n            }\n        }\n    );\n\n    let data = await request.bind(this)('get-newsletter-subscription', params, { auth: true, fetchOptions: fetchOptions || null });\n    let list = data?.list || data;\n    \n    let result = [];\n    if(!Array.isArray(list)) {\n        list = [];\n    }\n    for (let sub of list) {\n        let subt = sub['subt'].split('#');\n        let active = true;\n\n        if (subt[0].charAt(0) === '@') {\n            active = false;\n            subt[0] = subt[0].substring(1);\n        }\n\n        let group = parseInt(subt[0]);\n\n        result.push({\n            timestamp: sub['stmp'],\n            group,\n            subscribed_email: subt[1],\n            active\n        });\n    }\n\n    if(data?.list) {\n        data.list = result;\n        return data;\n    }\n\n    return result;\n}\n\n/**\n * Anyone who submits their E-Mail address will receive newsletters from you.<br>\n * The newsletters you send out will have unsubscribe link at the bottom.<br>\n * Both Signed and unsigned users can subscribe to your newsletter.<br>\n * Signed users can also subscribe to groups other than 0.\n * redirect is for newsletter subscribe confirmation link which it will only be sent to group 0 subscribers.\n * ```\n * let params = {\n *      email: 'visitors@email.com'\n * };\n * \n * skapi.subscribeNewsletter(params);\n * ```\n */\nexport async function subscribeNewsletter(\n    form: Form<{\n        email?: string;\n        group: number | 'public' | 'authorized' | 'admin' | string; \n        redirect?: string;\n    }>\n): Promise<string> {\n    await this.__connection;\n\n    let params = validator.Params(\n        form || {},\n        {\n            email: (v: string) => {\n                if(Array.isArray(v) && v.length > 0) {\n                    if(v.length === 1) {\n                        return validator.Email(v[0]);\n                    }\n                    else {\n                        return v.map(e => validator.Email(e));\n                    }\n                }\n                return validator.Email(v);\n            },\n            group: ['number', 'public', 'authorized', 'admin', (v: string) => {\n                if (typeof v !== 'string' || v.length > 20 || !/^[a-zA-Z0-9]+$/.test(v)) {\n                    throw new SkapiError('\"group\" should be an alphanumeric string without spaces and less than 20 characters.', { code: 'INVALID_PARAMETER' });\n                }\n                return v;\n            }], \n            redirect: (v: string) => validator.Url(v)\n        },\n        this.__user ? ['group'] : ['email', 'group']\n    );\n\n    return request.bind(this)(`subscribe-${this.__user ? '' : 'public-'}newsletter`, params, { auth: !!this.__user });\n}\n\n// /* depricate from the user api */\n// export async function adminNewsletterRequest(params) {\n//     await this.__connection;\n//     let response = await request.bind(this)('admin-newsletter-request', params, { auth: true });\n\n//     return response\n// }\n\n// /* depricate from the user api */\n// export async function registerNewsletterGroup(\n//     form: Form<{\n//         group: string;\n//         restriction: number;\n//     }>\n// ): Promise<string> {\n//     await this.__connection;\n\n//     let params = validator.Params(\n//         form || {},\n//         {\n//             group: (v: string) => {\n//                 if (typeof v !== 'string' || v.length > 20 || !/^[a-zA-Z0-9]+$/.test(v)) {\n//                     throw new SkapiError('\"group\" should be an alphanumeric string without spaces and less than 20 characters.', { code: 'INVALID_PARAMETER' });\n//                 }\n//                 return v;\n//             },\n//             restriction: (v: number) => {\n//                 if (typeof v !== 'number' || v < 0 || v > 99) {\n//                     throw new SkapiError('\"restriction\" should be a number between 0 and 99.', { code: 'INVALID_PARAMETER' });\n//                 }\n//                 return v;\n//             }\n//         },\n//         ['group', 'restriction']\n//     );\n\n//     return request.bind(this)('register-newsletter-group', params, { auth: true });\n// }\n\n// /* depricate from the user api */\n// export async function newsletterGroupEndpoint(params) {\n//     await this.__connection;\n//     let response = await request.bind(this)('newsletter-group-endpoint', params, { auth: true });\n\n//     return response\n// }\n\n/**\n * Only signed users can unsubscribe newsletter via api.\n * if form.group is null, unsubscribes from all groups.\n */\nexport async function unsubscribeNewsletter(\n    params: { group: number | 'public' | 'authorized' | 'admin' | null; }\n): Promise<string> {\n    await this.__connection;\n\n    params = validator.Params(\n        params,\n        {\n            group: ['number', 'public', 'authorized', 'admin']\n        },\n        ['group']\n    );\n\n    let param_send = Object.assign({\n        action: 'unsubscribe'\n    }, params);\n\n    return request.bind(this)('subscribe-newsletter', param_send, { auth: true });\n}\n\nexport async function getNewsletters(\n    params?: {\n        /**\n         * Search points.<br>\n         * 'message_id' and 'subject' value should be string.<br>\n         * Others numbers.\n         */\n        searchFor: 'message_id' | 'timestamp' | 'read' | 'complaint' | 'subject';\n        value: string | number;\n        group: 'public' | 'authorized' | number;\n        range?: string | number;\n        /**\n         * Defaults to '='\n         */\n        condition?: '>' | '>=' | '=' | '<' | '<=' | 'gt' | 'gte' | 'eq' | 'lt' | 'lte';\n    },\n    fetchOptions?: FetchOptions\n): Promise<DatabaseResponse<Newsletter>> {\n    let isAdmin = await checkAdmin.bind(this)();\n\n    let searchType = {\n        'message_id': 'string',\n        'timestamp': 'number',\n        'read': 'number',\n        'complaint': 'number',\n        'subject': 'string',\n        'bounced': 'number'\n    };\n\n    if (!params) {\n        fetchOptions = Object.assign({ ascending: false }, (fetchOptions || {}));\n    }\n\n    params = extractFormData(params).data as any;\n\n    params = params || {\n        searchFor: 'timestamp',\n        value: Date.now(),\n        condition: '<',\n        group: 'public'\n    };\n\n    params = validator.Params(params, {\n        searchFor: [\n            \"message_id\",\n            \"timestamp\",\n            \"subject\",\n            \"complaint\",\n            \"read\",\n            \"bounced\",\n        ],\n        value: (v: number | string) => {\n            if (typeof v !== searchType[params.searchFor]) {\n                throw new SkapiError(`\"value\" type does not match the type of \"${params.searchFor}\" index.`, { code: 'INVALID_PARAMETER' });\n            }\n            else if (typeof v === 'string' && !v) {\n                throw new SkapiError('\"value\" should not be empty string.', { code: 'INVALID_PARAMETER' });\n            }\n\n            return v;\n        },\n        range: (v: number | string) => {\n            if (!params.hasOwnProperty('value') || typeof v !== typeof params.value) {\n                throw new SkapiError('\"range\" should match type of \"value\".', { code: 'INVALID_PARAMETER' });\n            }\n            return v;\n        },\n        condition: ['>', '>=', '=', '<', '<=', 'gt', 'gte', 'eq', 'lt', 'lte', () => '='],\n        group: (x: number | string) => {\n            if (x === 'public') {\n                return 0;\n            }\n\n            if (!this.session) {\n                throw new SkapiError('User should be logged in.', { code: 'INVALID_REQUEST' });\n            }\n\n            if (x === 'authorized') {\n                return 1;\n            }\n\n            if (typeof x === 'number') {\n                if (!isAdmin && x > parseInt(this.user?.access_group || this.session?.idToken?.payload?.access_group)) {\n                    throw new SkapiError('User has no access.', { code: 'INVALID_REQUEST' });\n                }\n\n                return x;\n            }\n\n            throw new SkapiError('\"group\" should be type: number | \"public\" | \"authorized\".', { code: 'INVALID_PARAMETER' });\n        }\n    }, ['searchFor', 'value', 'group']);\n\n    let endpointTarget = params.group === 0 ? 'get-public-newsletters' : 'get-newsletters';\n    let mails = await request.bind(this)(\n        endpointTarget,\n        params,\n        Object.assign({ method: 'get', auth: endpointTarget === 'get-public-newsletters' ? !!this.__user : true }, { fetchOptions })\n    );\n\n    let remap = {\n        'message_id': 'mid',\n        'timestamp': 'stmp',\n        'complaint': 'cmpl',\n        'read': 'read',\n        'subject': 'subj',\n        'bounced': 'bnce',\n        'url': 'url',\n        'delivered': 'delv'\n    };\n    let defaults = {\n        'message_id': '',\n        'timestamp': 0,\n        'complaint': 0,\n        'read': 0,\n        'subject': '',\n        'bounced': '',\n        'url': '',\n        'delivered': 0\n    };\n\n    mails.list = mails.list.map(m => {\n        let remapped = {};\n        for (let k in remap) {\n            remapped[k] = m[remap[k]] || defaults[k];\n        }\n        remapped['bounced'] = String(remapped['bounced']);\n        return remapped;\n    });\n\n    return mails;\n}","import validator from '../utils/validator';\nimport { request } from '../utils/network';\nimport { checkAdmin } from './user';\nimport { Form, UserAttributes, UserProfile, UserPublic, DatabaseResponse, FetchOptions } from '../Types';\nimport SkapiError from '../main/error';\nimport { parseUserAttributes } from '../utils/utils';\n\nexport async function blockAccount(form: Form<{\n    user_id: string;\n    owner?: string;\n    service?: string;\n}>): Promise<'SUCCESS: The user has been blocked.'> {\n    let params = validator.Params(form, {\n        user_id: (v: string) => {\n            return validator.UserId(v, '\"user_id\"');\n        },\n    }, ['user_id']);\n\n    if (params?.service && params?.owner) {\n        params = { service: params?.service, owner: params?.owner, block: params.user_id };\n    }\n    else {\n        params = { block: params.user_id };\n    }\n\n    let isAdmin = await checkAdmin.bind(this)();\n\n    if (!isAdmin) {\n        if (!this.__user) {\n            throw new SkapiError('User needs to login.', { code: 'INVALID_REQUEST' });\n        }\n\n        if (this.__user.access_group < 90) {\n            throw new SkapiError('Invalid access.', { code: 'INVALID_REQUEST' });\n        }\n    }\n\n    return await request.bind(this)('block-account', params, { auth: true });\n}\n\nexport async function unblockAccount(form: Form<{\n    user_id: string;\n    owner?: string;\n    service?: string;\n}>): Promise<'SUCCESS: The user has been unblocked.'> {\n    let params = validator.Params(form, {\n        user_id: (v: string) => {\n            return validator.UserId(v, '\"user_id\"');\n        },\n    }, ['user_id']);\n\n    if (params?.service && params?.owner) {\n        params = { service: params?.service, owner: params?.owner, unblock: params.user_id };\n    } else {\n        params = { unblock: params.user_id };\n    }\n\n    let isAdmin = await checkAdmin.bind(this)();\n\n    if (!isAdmin) {\n        if (!this.__user) {\n            throw new SkapiError('User needs to login.', { code: 'INVALID_REQUEST' });\n        }\n\n        if (this.__user.access_group < 90) {\n            throw new SkapiError('Invalid access.', { code: 'INVALID_REQUEST' });\n        }\n    }\n\n    return await request.bind(this)('block-account', params, { auth: true });\n}\n\nexport async function deleteAccount(form: Form<{\n    user_id: string;\n    owner?: string;\n    service?: string;\n}>): Promise<'SUCCESS: Account has been deleted.'> {\n    let params = validator.Params(form, {\n        user_id: (v: string) => {\n            return validator.UserId(v, '\"user_id\"');\n        },\n    }, ['user_id']);\n\n    if (params?.service && params?.owner) {\n        params = { service: params?.service, owner: params?.owner, delete: params.user_id };\n    } else {\n        params = { delete: params.user_id };\n    }\n\n    let isAdmin = await checkAdmin.bind(this)();\n\n    if (!isAdmin) {\n        if (!this.__user) {\n            throw new SkapiError('User needs to login.', { code: 'INVALID_REQUEST' });\n        }\n\n        if (this.__user.access_group < 90) {\n            throw new SkapiError('Invalid access.', { code: 'INVALID_REQUEST' });\n        }\n    }\n\n    return await request.bind(this)('remove-account', params, { auth: true });\n}\n\nexport async function inviteUser(\n    form: Form<UserAttributes & { openid_id: string; access_group: number; } & { service?: string; owner?: string; }>,\n    options?: {\n        confirmation_url?: string;\n        email_subscription?: boolean;\n        template?: {\n            url: string;\n            subject: string;\n        }\n    }\n): Promise<'SUCCESS: Invitation has been sent. (User ID: xxx...)'> {\n    let paramRestrictions = {\n        email: (v: string) => validator.Email(v),\n        password: (v: string) => validator.Password(v),\n\n        name: 'string',\n        username: 'string',\n        gender: 'string',\n        address: (v: any) => {\n            if (!v) return '';\n\n            if (typeof v === 'string') {\n                return v;\n            }\n\n            if (typeof v === 'object') {\n                return JSON.stringify(v);\n            }\n\n            return undefined;\n        },\n        birthdate: (v: string) => validator.Birthdate(v),\n        phone_number: (v: string) => validator.PhoneNumber(v),\n        picture: (v: string) => { if (v) return validator.Url(v); else return undefined },\n        profile: (v: string) => { if (v) return validator.Url(v); else return undefined },\n        website: (v: string) => { if (v) return validator.Url(v); else return undefined },\n        nickname: 'string',\n        misc: 'string',\n\n        email_public: ['boolean', () => false],\n        gender_public: ['boolean', () => false],\n        address_public: ['boolean', () => false],\n        birthdate_public: ['boolean', () => false],\n        phone_number_public: ['boolean', () => false],\n        openid_id: 'string',\n        access_group: (v: number) => {\n            // if string try to convert to number and if it's not a number, throw error\n            try {\n                if (typeof v === 'string') {\n                    v = v === 'admin' ? 99 : parseInt(v);\n                }\n            }\n            catch (e) {\n                throw new SkapiError('\"access_group\" is invalid. Should be type <number>.', { code: 'INVALID_PARAMETER' });\n            }\n            if (typeof v !== 'number' || v < 1 || v > 100) {\n                throw new SkapiError('\"access_group\" is invalid. Should be type <number> of range 1~99', { code: 'INVALID_PARAMETER' });\n            }\n            return v;\n        }\n    };\n\n    let params = validator.Params(form, paramRestrictions, ['email']);\n\n    options = validator.Params(options, {\n        confirmation_url: (v: string) => {\n            let value = v;\n\n            if (typeof v === 'string') {\n                value = validator.Url(v);\n            }\n            else {\n                throw new SkapiError('\"options.confirmation_url\" should be type: <string>.', { code: 'INVALID_PARAMETER' });\n            }\n\n            if (value && !params.email) {\n                throw new SkapiError('\"email\" is required for signup confirmation.', { code: 'INVALID_PARAMETER' });\n            }\n\n            return value;\n        },\n        email_subscription: (v: boolean) => {\n            if (typeof v !== 'boolean') {\n                throw new SkapiError('\"options.email_subscription\" should be type: <boolean>.', { code: 'INVALID_PARAMETER' });\n            }\n            if (!options?.confirmation_url) {\n                // requires to be url or true\n                throw new SkapiError('\"options.confirmation_url\" is required for email subscription.', { code: 'INVALID_PARAMETER' });\n            }\n            return v;\n        },\n        template: (v: { url: string; subject: string; }) => {\n            if (typeof v !== 'object' || !v.url || !v.subject) {\n                throw new SkapiError('\"options.template\" should be type: <object> with \"url\" and \"subject\".', { code: 'INVALID_PARAMETER' });\n            }\n            return {\n                url: validator.Url(v.url),\n                subject: v.subject,\n            };\n        },\n    });\n\n    params.signup_confirmation = options?.confirmation_url || true;\n    params.email_subscription = options?.email_subscription || false;\n    params.template = options?.template || {};\n\n    let isAdmin = await checkAdmin.bind(this)();\n\n    if (!isAdmin) {\n        if (!this.__user) {\n            throw new SkapiError('User needs to login.', { code: 'INVALID_REQUEST' });\n        }\n\n        if (this.__user.access_group < 90) {\n            throw new SkapiError('Invalid access.', { code: 'INVALID_REQUEST' });\n        }\n    }\n\n    return await request.bind(this)('admin-signup', params, { auth: true });\n}\n\nexport async function createAccount(\n    form: Form<\n        UserAttributes & { access_group: number; password: string; } &\n        { service?: string; owner?: string; }\n    >,\n): Promise<UserProfile & { email_admin: string; username: string; }> {\n    let paramRestrictions = {\n        email: (v: string) => validator.Email(v),\n        password: (v: string) => validator.Password(v),\n        openid_id: 'string',\n        name: 'string',\n        username: 'string',\n        gender: 'string',\n        address: (v: any) => {\n            if (!v) return '';\n\n            if (typeof v === 'string') {\n                return v;\n            }\n\n            if (typeof v === 'object') {\n                return JSON.stringify(v);\n            }\n\n            return undefined;\n        },\n        birthdate: (v: string) => validator.Birthdate(v),\n        phone_number: (v: string) => validator.PhoneNumber(v),\n        picture: (v: string) => { if (v) return validator.Url(v); else return \"\" },\n        profile: (v: string) => { if (v) return validator.Url(v); else return \"\" },\n        website: (v: string) => { if (v) return validator.Url(v); else return \"\" },\n        nickname: 'string',\n        misc: 'string',\n\n        email_public: ['boolean', () => false],\n        gender_public: ['boolean', () => false],\n        address_public: ['boolean', () => false],\n        birthdate_public: ['boolean', () => false],\n        phone_number_public: ['boolean', () => false],\n        access_group: (v: number) => {\n            // if string try to convert to number and if it's not a number, throw error\n            try {\n                if (typeof v === 'string') {\n                    v = parseInt(v);\n                }\n            }\n            catch (e) {\n                throw new SkapiError('\"access_group\" is invalid. Should be type <number>.', { code: 'INVALID_PARAMETER' });\n            }\n            if (typeof v !== 'number' || v < 1 || v > 100) {\n                throw new SkapiError('\"access_group\" is invalid. Should be type <number> of range 1~99', { code: 'INVALID_PARAMETER' });\n            }\n            return v;\n        },\n    };\n\n    let params = validator.Params(form, paramRestrictions, ['email', 'password']);\n\n    let isAdmin = await checkAdmin.bind(this)();\n\n    if (!isAdmin) {\n        if (!this.__user) {\n            throw new SkapiError('User needs to login.', { code: 'INVALID_REQUEST' });\n        }\n\n        if (this.__user.access_group < 90) {\n            throw new SkapiError('Invalid access.', { code: 'INVALID_REQUEST' });\n        }\n    }\n\n    return await request.bind(this)('admin-signup', params, { auth: true });\n}\n\nexport async function grantAccess(params: Form<{\n    user_id: string;\n    access_group: number;\n    service?: string;\n    owner?: string;\n}>): Promise<'SUCCESS: Access has been granted to the user.'> {\n    params = validator.Params(params, {\n        user_id: (v: string) => {\n            return validator.UserId(v, '\"user_id\"');\n        },\n        access_group: (v: number) => {\n            // if string try to convert to number and if it's not a number, throw error\n            try {\n                if (typeof v === 'string') {\n                    v = parseInt(v);\n                }\n            }\n            catch (e) {\n                throw new SkapiError('\"access_group\" is invalid. Should be type <number>.', { code: 'INVALID_PARAMETER' });\n            }\n            if (typeof v === 'number' && v > 0 && v < 100) {\n                return v;\n            } else {\n                throw new SkapiError('\"access_group\" is invalid. Should be type <number> of range 1~99', { code: 'INVALID_PARAMETER' });\n            }\n        }\n    }, ['user_id', 'access_group']);\n\n    let isAdmin = await checkAdmin.bind(this)();\n\n    if (!isAdmin) {\n        if (!this.__user) {\n            throw new SkapiError('User needs to login.', { code: 'INVALID_REQUEST' });\n        }\n\n        if (this.__user.access_group < 90) {\n            throw new SkapiError('Invalid access.', { code: 'INVALID_REQUEST' });\n        }\n    }\n\n    return await request.bind(this)('grant-access', params, { auth: true })\n}\n\nexport async function getInvitations(params?: Form<{\n    service?: string;\n    owner?: string;\n    email?: string;\n}>, fetchOptions?: FetchOptions): Promise<DatabaseResponse<UserProfile>> {\n    params = validator.Params(params, {\n        email: 'string',\n    });\n\n    let isAdmin = await checkAdmin.bind(this)();\n\n    if (!isAdmin) {\n        if (!this.__user) {\n            throw new SkapiError('User needs to login.', { code: 'INVALID_REQUEST' });\n        }\n\n        if (this.__user.access_group < 90) {\n            throw new SkapiError('Invalid access.', { code: 'INVALID_REQUEST' });\n        }\n    }\n\n    let resp = await request.bind(this)('invitation-list', Object.assign({ mode: 'search' }, params), { fetchOptions, auth: true });\n    resp.list = resp.list.map((v: any) => parseUserAttributes(v.user));\n    return resp;\n}\n\nexport async function cancelInvitation(params: Form<{\n    service?: string;\n    owner?: string;\n    email: string;\n}>): Promise<\"SUCCESS: Invitation has been canceled.\"> {\n    params = validator.Params(params, {\n        email: v => validator.Email(v),\n    }, ['email']);\n\n    let isAdmin = await checkAdmin.bind(this)();\n\n    if (!isAdmin) {\n        if (!this.__user) {\n            throw new SkapiError('User needs to login.', { code: 'INVALID_REQUEST' });\n        }\n\n        if (this.__user.access_group < 90) {\n            throw new SkapiError('Invalid access.', { code: 'INVALID_REQUEST' });\n        }\n    }\n\n    return await request.bind(this)('invitation-list', Object.assign({ mode: 'cancel' }, params), { auth: true });\n}\n\nexport async function resendInvitation(params: Form<{\n    service?: string;\n    owner?: string;\n    email: string;\n}>): Promise<\"SUCCESS: Invitation has been re-sent. (User ID: xxx...)\"> {\n    params = validator.Params(params, {\n        email: v => validator.Email(v),\n    }, ['email']);\n\n    let isAdmin = await checkAdmin.bind(this)();\n\n    if (!isAdmin) {\n        if (!this.__user) {\n            throw new SkapiError('User needs to login.', { code: 'INVALID_REQUEST' });\n        }\n\n        if (this.__user.access_group < 90) {\n            throw new SkapiError('Invalid access.', { code: 'INVALID_REQUEST' });\n        }\n    }\n\n    return await request.bind(this)('invitation-list', Object.assign({ mode: 'resend' }, params), { auth: true });\n}","import { SkapiError } from \"../Main\";\nimport { request } from \"../utils/network\";\nimport { extractFormData } from \"../utils/utils\";\n\nexport async function subscribeNotification(params: {\n  endpoint: string;\n  keys: {\n    p256dh: string;\n    auth: string;\n  };\n}): Promise<\"SUCCESS: Subscribed to receive notifications.\"> {\n  if (typeof window === 'undefined' || (window as any)._runningInNodeJS) {\n    throw new SkapiError('Push Notifications are not supported in Node.js environment.', { code: 'NOT_SUPPORTED' });\n  }\n  await this.__connection;\n\n  if (!params.endpoint) {\n    throw new SkapiError(\"Missing parameter: endpoint\", {\n      code: \"INVALID_PARAMETER\",\n    });\n  }\n  if (!params.keys || !params.keys.p256dh || !params.keys.auth) {\n    throw new SkapiError(\"Missing parameter: keys.p256dh or keys.auth\", {\n      code: \"INVALID_PARAMETER\",\n    });\n  }\n\n  await request.bind(this)(\n    \"store-subscription\",\n    { endpoint: params.endpoint, keys: params.keys },\n    { auth: true }\n  );\n\n  return \"SUCCESS: Subscribed to receive notifications.\";\n}\n\nexport async function unsubscribeNotification(params: {\n  endpoint: string;\n  keys: {\n    p256dh: string;\n    auth: string;\n  };\n}): Promise<\"SUCCESS: Unsubscribed from notifications.\"> {\n  if (typeof window === 'undefined' || (window as any)._runningInNodeJS) {\n    throw new SkapiError('Push Notifications are not supported in Node.js environment.', { code: 'NOT_SUPPORTED' });\n  }\n  await this.__connection;\n\n  if (!params.endpoint) {\n    throw new SkapiError(\"Missing parameter: endpoint\", {\n      code: \"INVALID_PARAMETER\",\n    });\n  }\n  if (!params.keys || !params.keys.p256dh || !params.keys.auth) {\n    throw new SkapiError(\"Missing parameter: keys.p256dh or keys.auth\", {\n      code: \"INVALID_PARAMETER\",\n    });\n  }\n\n  await request.bind(this)(\n    \"delete-subscription\",\n    { endpoint: params.endpoint, keys: params.keys },\n    { auth: true }\n  );\n  return \"SUCCESS: Unsubscribed from notifications.\";\n}\n\n\nexport async function vapidPublicKey() {\n  if (typeof window === 'undefined' || (window as any)._runningInNodeJS) {\n    throw new SkapiError('Push Notifications are not supported in Node.js environment.', { code: 'NOT_SUPPORTED' });\n  }\n  await this.__connection;\n\n  let vapid = await request.bind(this)(\"get-vapid-public-key\", null, {\n    auth: true,\n  });\n\n  return { VAPIDPublicKey: vapid };\n}\n\nexport async function pushNotification(\n  form: {\n    title: string;\n    body: string;\n  },\n  user_ids?: string | string[]): Promise<\"SUCCESS: Notification sent.\"> {\n  if (typeof window === 'undefined' || (window as any)._runningInNodeJS) {\n    throw new SkapiError('Push Notifications are not supported in Node.js environment.', { code: 'NOT_SUPPORTED' });\n  }\n  await this.__connection;\n\n  let { title, body } = extractFormData(form || {}, { nullIfEmpty: true }).data;\n\n  if (!title) {\n    throw new SkapiError(\"Missing parameter: message title\", {\n      code: \"INVALID_PARAMETER\",\n    });\n  }\n  if (!body) {\n    throw new SkapiError(\"Missing parameter: message body\", {\n      code: \"INVALID_PARAMETER\",\n    });\n  }\n\n  const payload = { title, body };\n\n  if (user_ids) {\n    if (typeof user_ids === 'string') {\n      user_ids = [user_ids];\n    }\n    payload['user_ids'] = user_ids;\n  }\n  else {\n    payload['user_ids'] = 'all_users';\n  }\n\n  await request.bind(this)(\n    \"push-notification\",\n    payload,\n    {\n      auth: true,\n    }\n  );\n\n  return \"SUCCESS: Notification sent.\";\n}\n","import { request } from '../utils/network';\nimport validator from '../utils/validator';\nimport {\n    isBrowserRuntime,\n} from '../utils/utils';\nimport {\n    DatabaseResponse,\n} from '../Types';\nexport async function spellcast(params: {\n    spell: string,\n    name: string,\n    magic?: any\n}): Promise<string> {\n    await this.__connection;\n    params = validator.Params(params, {\n        'spell': 'string',\n        'name': 'string',\n        'magic': x=>x\n    }, ['spell', 'name'])\n\n    let response = await request.bind(this)('castspell', params);\n    return `The spell \"${params.spell}\" has been cast.`;\n}\n\nexport async function getspell(params?: {\n    search?: 'spell' | 'name',\n    value?: string,\n}): Promise<DatabaseResponse<{\n    spell: string;\n    magic?: any;\n    name: string;\n}>> {\n    await this.__connection;\n    params = validator.Params(params || {}, {\n        'search': ['spell', 'name', () => \"spell\"],\n        'value': 'string'\n    });\n\n    let response = await request.bind(this)('getspell', params);\n    return response;\n}\n\nexport async function dopamine(params: {\n    message: string,\n    name: string\n}): Promise<string> {\n    await this.__connection;\n    params = validator.Params(params, {\n        'message': 'string',\n        'name': 'string'\n    }, ['message', 'name'])\n\n    let response = await request.bind(this)('dopamine', params, { auth: true });\n\n    let message = response?.previous_message?.message;\n    let name = response?.previous_message?.name;\n\n    if (isBrowserRuntime()) {\n        if (message && name)\n            window.alert(`${name} said: ${message}`)\n\n        window.location.href = response.video\n    }\n    else {\n        if(message && name) {\n            return `${name} said: ${message}\\nWatch the video here: ${response.video}`;\n        }\n        else {\n            return `Your message has been uploaded for future generations to receive.\\nWatch the video here: ${response.video}`;\n        }\n    }\n}","import {\n    DatabaseResponse,\n    Connection,\n    ProgressCallback,\n    GetRecordQuery,\n    FetchOptions,\n    RecordData,\n    Condition,\n    UserAttributes,\n    UserProfile,\n    Newsletter,\n    Form,\n    PostRecordConfig,\n    UserPublic,\n    FileInfo,\n    RTCEvent,\n    RealtimeCallback,\n    RTCConnectorParams,\n    RTCConnector,\n    DelRecordQuery,\n    ConnectionInfo,\n    Table,\n    Index,\n    Tag,\n    UniqueId,\n    Subscription,\n} from '../Types';\nimport {\n    CognitoUserPool\n} from 'amazon-cognito-identity-js';\nimport SkapiError from './error';\nimport validator from '../utils/validator';\nimport {\n    getRecords,\n    postRecord,\n    deleteRecords,\n    getTables,\n    getIndexes,\n    getTags,\n    getFile,\n    grantPrivateRecordAccess,\n    removePrivateRecordAccess,\n    listPrivateRecordAccess,\n    requestPrivateRecordAccessKey,\n    deleteFiles,\n    getUniqueId,\n    bulkPostRecords\n} from '../methods/database';\nimport {\n    connectRealtime,\n    joinRealtime,\n    postRealtime,\n    closeRealtime,\n    getRealtimeUsers,\n    getRealtimeGroups,\n} from '../methods/realtime';\nimport {\n    closeRTC,\n    connectRTC\n} from '../methods/webrtc';\nimport {\n    secureRequest,\n    mock,\n    clientSecretRequest,\n    sendInquiry\n} from '../methods/request';\nimport {\n    request,\n    getFormResponse,\n    formHandler,\n    uploadFiles,\n    terminatePendingRequests\n} from '../utils/network';\nimport {\n    subscribe,\n    unsubscribe,\n    blockSubscriber,\n    unblockSubscriber,\n    getSubscriptions,\n    subscribeNewsletter,\n    getNewsletters,\n    unsubscribeNewsletter,\n    getNewsletterSubscription,\n    getFeed,\n    // adminNewsletterRequest,\n    // registerNewsletterGroup,\n    // newsletterGroupEndpoint,\n} from '../methods/subscription';\nimport {\n    getProfile,\n    logout,\n    recoverAccount,\n    resendSignupConfirmation,\n    authentication,\n    login,\n    signup,\n    disableAccount,\n    resetPassword,\n    verifyEmail,\n    verifyPhoneNumber,\n    forgotPassword,\n    changePassword,\n    updateProfile,\n    getUsers,\n    lastVerifiedEmail,\n    requestUsernameChange,\n    consumeTicket,\n    getConsumedTickets,\n    getTickets,\n    registerTicket,\n    unregisterTicket,\n    _out,\n    openIdLogin,\n    loginWithToken\n} from '../methods/user';\nimport {\n    extractFormData,\n    fromBase62,\n    generateRandom,\n    toBase62,\n    MD5,\n    isBrowserRuntime,\n    isNodeRuntime,\n    decodeServiceId,\n    formatServiceId,\n} from '../utils/utils';\nimport {\n    blockAccount,\n    unblockAccount,\n    deleteAccount,\n    inviteUser,\n    createAccount,\n    grantAccess,\n    getInvitations,\n    cancelInvitation,\n    resendInvitation\n} from '../methods/admin';\nimport {\n    subscribeNotification,\n    vapidPublicKey,\n    pushNotification,\n    unsubscribeNotification\n} from '../methods/notification';\nimport {\n    spellcast, dopamine, getspell\n} from '../methods/vivian';\n\ndeclare const __SKAPI_VERSION__: string;\n\ntype Options = {\n    autoLogin: boolean;\n    requestBatchSize?: number; // default 30. number of requests to be handled in a batch\n    // bearerToken?: string; // custom bearer token for authentication\n    eventListener?: {\n        onLogin?: (user: UserProfile | null) => void;\n        onUserUpdate?: (user: UserProfile | null) => void;\n        onBatchProcess?: (process: {\n            batchToProcess: number;\n            itemsToProcess: number;\n            completed: any[];\n        }) => void;\n    },\n}\n\nexport default class Skapi {\n    // current version\n    private __version = __SKAPI_VERSION__;\n    service: string;\n    owner: string;\n    session: Record<string, any> | null = null;\n    connection: Connection | null = null;\n    private __my_unique_ids: { [rec_id: string]: string } = {};\n    private userPool: CognitoUserPool | null = null;\n    private __socket: Promise<WebSocket> | null = null;\n    private __mediaStream: MediaStream = null;\n\n    private host = 'skapi';\n    private hostDomain = 'skapi.com';\n    private target_cdn = 'd3e9syvbtso631';\n    private customApiDomain = 'skapi.dev';\n    private requestBatchSize = 30;\n\n    // privates\n    private __disabledAccount: string | null = null;\n    private __cached_requests: {\n        /** Cached url requests */\n        [url: string]: {\n            /** Array of data stored in hashed params key */\n            [hashedParams: string]: DatabaseResponse<any>;\n        };\n    } = {};\n\n    private __startKeyHistory: {\n        /** List of startkeys */\n        [url: string]: {\n            [hashedParams: string]: string[];\n        };\n    } = {};\n    private __request_signup_confirmation: string | null = null;\n    private __private_access_key: {\n        [record_id: string]: string;\n    } = {}\n\n    // true when session is stored successfully to session storage\n    // this property prevents duplicate stores when window closes on some device\n    private __class_properties_has_been_cached = false;\n\n    /** Current logged in user object. null if not logged. */\n    private __user: UserProfile | null = null;\n\n    get user(): UserProfile | null {\n        if (this.__user && Object.keys(this.__user).length) {\n            return JSON.parse(JSON.stringify(this.__user));\n        }\n        else {\n            return null;\n        }\n    }\n\n    set user(value) {\n        // setting user is bypassed\n    }\n\n    private _userProfileListeners: Function[] = [];\n    private _onLoginListeners: Function[] = [];\n\n    get onLogin(): Function[] {\n        return this._onLoginListeners;\n    }\n\n    set onLogin(listener: (user: UserProfile | null) => void) {\n        if (typeof listener === 'function') {\n            this._onLoginListeners.push(listener);\n        }\n    }\n\n    get onUserUpdate(): Function[] {\n        return this._userProfileListeners;\n    }\n\n    set onUserUpdate(listener: (user: UserProfile | null) => void) {\n        if (typeof listener === 'function') {\n            this._userProfileListeners.push(listener);\n        }\n    }\n\n    private _runOnUserUpdateListeners(user: UserProfile | null) {\n        for (let listener of this._userProfileListeners) {\n            if (typeof listener === 'function') {\n                listener(user);\n            }\n        }\n    }\n\n    private _runOnLoginListeners(user: UserProfile | null) {\n        for (let listener of this._onLoginListeners) {\n            if (typeof listener === 'function') {\n                listener(user);\n            }\n        }\n    }\n\n    private admin_endpoint: Promise<Record<string, any>>;\n    private record_endpoint: Promise<Record<string, any>>;\n\n    private _onBatchProcessListeners: ((process: {\n        batchToProcess: number;\n        itemsToProcess: number;\n        completed: any[];\n    }) => void)[] = [];\n\n    get onBatchProcess(): ((process: {\n        batchToProcess: number;\n        itemsToProcess: number;\n        completed: any[];\n    }) => void)[] {\n        return this._onBatchProcessListeners;\n    }\n\n    set onBatchProcess(listener: (process: {\n        batchToProcess: number;\n        itemsToProcess: number;\n        completed: any[];\n    }) => void) {\n        if (typeof listener === 'function') {\n            this._onBatchProcessListeners.push(listener);\n        }\n    }\n\n    validate = {\n        userId(val: string) {\n            try {\n                validator.UserId(val);\n                return true;\n            } catch (err) {\n                return false;\n            }\n        },\n        url(val: string | string[]) {\n            try {\n                validator.Url(val);\n                return true;\n            } catch (err) {\n                return false;\n            }\n        },\n        phoneNumber(val: string) {\n            try {\n                validator.PhoneNumber(val);\n                return true;\n            } catch (err) {\n                return false;\n            }\n        },\n        birthdate(val: string) {\n            try {\n                validator.Birthdate(val);\n                return true;\n            } catch (err) {\n                return false;\n            }\n        },\n        email(val: string) {\n            try {\n                validator.Email(val);\n                return true;\n            } catch (err) {\n                return false;\n            }\n        },\n        params(val: any, schema: Record<string, any>, required?: string[]) {\n            return validator.Params(val, schema, required);\n        }\n    };\n\n    util = {\n        MD5,\n        generateRandom,\n        toBase62,\n        fromBase62,\n        decodeServiceId,\n        formatServiceId,\n        extractFormData,\n        terminatePendingRequests,\n        request: (\n            url: string,\n            data?: Form<any>,\n            options?: {\n                fetchOptions?: FetchOptions;\n                auth?: boolean;\n                method?: string;\n                bypassAwaitConnection?: boolean;\n                responseType?: 'json' | 'blob' | 'text' | 'arrayBuffer' | 'formData' | 'document';\n                contentType?: string;\n            }\n        ) => request.bind(this)(url, data, options, { ignoreService: true })\n    }\n\n    private __connection: Promise<Connection>;\n    private __authConnection: Promise<void>;\n    private __network_logs = false;\n    private __endpoint_version = 'v1';\n    private __public_identifier = '';\n    private bearerToken: string = '';\n\n    private _alert(message: string) {\n        if (isBrowserRuntime() && typeof window.alert === 'function') {\n            window.alert(message);\n        }\n    }\n\n    constructor(service: string, owner?: string | Options, options?: Options | any, __etc?: any) {\n        if (!service || typeof service !== 'string') {\n            this._alert(\"Service ID is required.\");\n            throw new SkapiError('Service ID is required.', { code: 'INVALID_PARAMETER' });\n        }\n        let idSplitLen = service.split(\"-\").length;\n        let isV2 = idSplitLen === 2;\n        let isV1 = idSplitLen === 7;\n        if (isV2 || isV1) {\n            try {\n                let decoded = decodeServiceId(service);\n                if (options && typeof options === 'object') {\n                    __etc = options;\n                }\n\n                if (owner && typeof owner === 'object') {\n                    options = owner;\n                }\n\n                owner = decoded.owner;\n                service = decoded.service;\n            }\n            catch (err) {\n                this._alert(\"Service ID is invalid.\");\n                throw new SkapiError('Service ID is invalid.', { code: 'INVALID_PARAMETER' });\n            }\n        }\n\n        // if (!window.sessionStorage) {\n        //     throw new SkapiError('Web browser API is not available.', { code: 'NOT_SUPPORTED' });\n        // }\n        // window.sessionStorage.setItem('__skapi_kiss', 'kiss');\n        // if (window.sessionStorage.getItem('__skapi_kiss') !== 'kiss') {\n        //     window.alert('Session storage is disabled. Please enable session storage.');\n        //     throw new SkapiError('Session storage is disabled. Please enable session storage.', { code: 'SESSION_STORAGE_DISABLED' });\n        // }\n\n        // window.sessionStorage.removeItem('__skapi_kiss');\n\n        if (!owner || typeof owner !== 'string') {\n            this._alert(\"Owner ID is invalid.\");\n            throw new SkapiError('Owner ID is invalid.', { code: 'INVALID_PARAMETER' });\n        }\n\n        if (service.toLowerCase() === 'service_id') {\n            this._alert('Replace \"service_id\" with your actual Service ID.');\n            throw new SkapiError('Service ID is required.', { code: 'INVALID_PARAMETER' });\n        }\n\n        if (owner !== this.host) {\n            try {\n                validator.UserId(owner, '\"owner\"');\n            } catch (err: any) {\n                this._alert(\"Owner ID is invalid.\");\n                throw new SkapiError('Owner ID is invalid.', { code: 'INVALID_PARAMETER' });\n            }\n        }\n\n        this.service = service;\n        this.owner = owner;\n\n        let autoLogin = true;\n\n        if (options) {\n            if (typeof options.autoLogin === 'boolean') {\n                autoLogin = options.autoLogin;\n            }\n            if (typeof options.requestBatchSize === 'number') {\n                if (options.requestBatchSize < 1) {\n                    throw new SkapiError('\"requestBatchSize\" must be greater than 0.', { code: 'INVALID_PARAMETER' });\n                }\n                this.requestBatchSize = options.requestBatchSize;\n            }\n        }\n\n        if (options?.eventListener && typeof options.eventListener === 'object') {\n            if (options.eventListener?.onLogin && typeof options.eventListener.onLogin === 'function') {\n                this.onLogin = options.eventListener.onLogin;\n            }\n\n            if (options.eventListener?.onUserUpdate && typeof options.eventListener.onUserUpdate === 'function') {\n                this.onUserUpdate = options.eventListener.onUserUpdate;\n            }\n\n            if (options.eventListener?.onBatchProcess && typeof options.eventListener.onBatchProcess === 'function') {\n                this.onBatchProcess = options.eventListener.onBatchProcess;\n            }\n        }\n\n        // get endpoints\n\n        this.target_cdn = __etc?.target_cdn || this.target_cdn;\n        this.hostDomain = __etc?.hostDomain || this.hostDomain;\n        this.customApiDomain = __etc?.customApiDomain || this.customApiDomain;\n\n        this.__network_logs = !!__etc?.network_logs;\n\n        const cdn_domain = `https://${this.target_cdn}.cloudfront.net`; // don't change this\n        let sreg = service.substring(0, 4);\n\n        this.admin_endpoint = fetch(`${cdn_domain}/${sreg}/admin-${this.__endpoint_version}.json`)\n            .then(response => response.blob())\n            .then(blob => new Promise((resolve, reject) => {\n                const reader = new FileReader();\n                reader.onloadend = () => resolve(reader.result);\n                reader.onerror = reject;\n                reader.readAsDataURL(blob);\n            }))\n            .then(data => {\n                try {\n                    return typeof data === 'string' ? JSON.parse(atob(data.split(',')[1])) : null\n                }\n                catch (err) {\n                    throw new SkapiError('Service does not exist. Create your service from skapi.com', { code: 'NOT_EXISTS' });\n                }\n            });\n\n        this.record_endpoint = fetch(`${cdn_domain}/${sreg}/record-${this.__endpoint_version}.json`)\n            .then(response => response.blob())\n            .then(blob => new Promise((resolve, reject) => {\n                const reader = new FileReader();\n                reader.onloadend = () => resolve(reader.result);\n                reader.onerror = reject;\n                reader.readAsDataURL(blob);\n            }))\n            .then(data => {\n                try {\n                    return typeof data === 'string' ? JSON.parse(atob(data.split(',')[1])) : null\n                }\n                catch (err) {\n                    throw new SkapiError('Service does not exist. Create your service from skapi.com', { code: 'NOT_EXISTS' });\n                }\n            });\n\n        const hasWindow = isBrowserRuntime();\n\n        if (hasWindow && !window.sessionStorage) {\n            this._alert('This browser is not supported.');\n            throw new Error(`This browser is not supported.`);\n        }\n\n        const restore = hasWindow ? JSON.parse(window.sessionStorage.getItem(`${service}#${owner}`) || 'null') : null;\n\n        this.log('constructor:restore', restore);\n\n        if (restore?.connection) {\n            // apply all data to class properties\n            for (let k in restore) {\n                this[k] = restore[k];\n            }\n\n            if (!restore.__public_identifier) {\n                this.__public_identifier = `${this.service}:${this.owner}:${generateRandom(16)}`;\n            }\n        }\n\n        this.__authConnection = (async (): Promise<void> => {\n            const admin_endpoint = await this.admin_endpoint;\n            const poolSetting = {\n                UserPoolId: admin_endpoint.userpool_id,\n                ClientId: admin_endpoint.userpool_client\n            } as any;\n            if (isNodeRuntime()) {\n                poolSetting.Storage = window.localStorage;\n            }\n            this.userPool = new CognitoUserPool(poolSetting);\n\n            try {\n                if (!this.user) {\n                    // if (autoLogin && typeof autoLogin === 'object') {\n                    //     let { idToken = '', accessToken = '', refreshToken = '' } = autoLogin || {};\n                    //     if (idToken) {\n                    //         await this.loginWithToken({ idToken, accessToken, refreshToken });\n                    //     }\n                    // }\n                    await authentication.bind(this)().getSession({\n                        skipUserUpdateEventTrigger: true\n                    });\n                }\n                if (this.user) {\n                    if (!restore?.connection && !autoLogin) {\n                        _out.bind(this)();\n                    }\n                    else {\n                        // only run login listeners if user is logged in (auto login successful)\n                        this._runOnLoginListeners(this.user);\n                        this._runOnUserUpdateListeners(this.user);\n                    }\n                }\n            }\n            catch (err) {\n            }\n        })()\n\n        let uniqueids = hasWindow ? window.sessionStorage.getItem(`${this.service}:uniqueids`) : null;\n        if (uniqueids) {\n            try {\n                this.__my_unique_ids = JSON.parse(uniqueids);\n            } catch (err) {\n                this.__my_unique_ids = {};\n            }\n        }\n\n        // connects to server\n        this.__connection = (async (): Promise<Connection> => {\n            let connection: Promise<Connection> = null;\n            await this.record_endpoint;\n\n            if (!restore?.connection) {\n                // await for first connection\n                connection = this._updateConnection();\n            }\n\n            const storeClassProperties = () => {\n                if (this.__class_properties_has_been_cached) {\n                    return;\n                }\n\n                let exec = () => {\n                    let data: Record<string, any> = {};\n\n                    const to_be_cached = [\n                        '__startKeyHistory', // startKey key : {}\n                        '__disabledAccount', // disabled account : null\n                        '__cached_requests', // cached records : {}\n                        '__request_signup_confirmation', // for resend signup confirmation : null\n                        '__public_identifier', // public identifier : ''\n                        'connection', // service info : null\n                    ];\n\n                    if (this.connection) {\n                        for (let k of to_be_cached) {\n                            data[k] = this[k];\n                        }\n\n                        if (hasWindow) {\n                            window.sessionStorage.setItem(`${service}#${owner}`, JSON.stringify(data));\n                        }\n                        this.__class_properties_has_been_cached = true;\n                    }\n                };\n\n                return (connection instanceof Promise) ? connection.then(() => exec()) : exec();\n            };\n\n            // attach event to save session on close\n            if (hasWindow) {\n                window.addEventListener('beforeunload', () => {\n                    this.closeRealtime();\n                    storeClassProperties();\n                });\n                // for mobile\n                window.addEventListener(\"visibilitychange\", () => {\n                    storeClassProperties();\n                });\n            }\n\n            await connection;\n            await this.__authConnection;\n            return this.connection;\n        })();\n\n        this.__connection.then(conn => {\n            if ((conn?.group || 0) < 3 || this.__network_logs) {\n                this.version();\n            }\n        });\n    }\n\n    /**\n     * Returns current connection metadata such as service name, client IP, user agent, locale, and SDK version.\n     * @returns A promise that resolves to Promise<ConnectionInfo>.\n     */\n    async getConnectionInfo(): Promise<ConnectionInfo> {\n        let conn = await this.__connection;\n        // get browser user-agent info\n        let ua = conn?.user_agent || (isBrowserRuntime() && typeof window.navigator?.userAgent === 'string'\n            ? window.navigator.userAgent\n            : `skapi-node/${(globalThis as any)?.process?.versions?.node || 'unknown'}`);\n        return {\n            user_ip: conn.ip,\n            user_agent: ua,\n            user_location: conn.locale,\n            service_name: conn.service_name,\n            version: this.__version\n        };\n    }\n\n    private async _updateConnection(): Promise<Connection> {\n        try {\n            this.connection = await request.bind(this)('service', {\n                service: this.service,\n                owner: this.owner\n            }, { bypassAwaitConnection: true, method: 'get' });\n        }\n        catch (err: any) {\n            this.log('connection fail', err);\n            this._alert('Service is not available: ' + (err.message || err.toString()));\n\n            this.connection = null;\n            throw err;\n        }\n        return this.connection;\n    }\n\n    private registerTicket = registerTicket.bind(this);\n    private unregisterTicket = unregisterTicket.bind(this);\n\n    /**\n     * Returns the current SDK version and prints runtime version details in browser environments.\n     * @returns A promise that resolves to Promise<string>.\n     */\n    async version(): Promise<string> {\n        await this.__connection;\n\n        if (isBrowserRuntime()) {\n            let skapi = `%c\\r\\n          $$\\\\                          $$\\\\ \\r\\n          $$ |                         \\\\__|\\r\\n $$$$$$$\\\\ $$ |  $$\\\\ $$$$$$\\\\   $$$$$$\\\\  $$\\\\ \\r\\n$$  _____|$$ | $$  |\\\\____$$\\\\ $$  __$$\\\\ $$ |\\r\\n\\\\$$$$$$\\\\  $$$$$$  \\/ $$$$$$$ |$$ \\/  $$ |$$ |\\r\\n \\\\____$$\\\\ $$  _$$< $$  __$$ |$$ |  $$ |$$ |\\r\\n$$$$$$$  |$$ | \\\\$$\\\\\\\\$$$$$$$ |$$$$$$$  |$$ |\\r\\n\\\\_______\\/ \\\\__|  \\\\__|\\\\_______|$$  ____\\/ \\\\__|\\r\\n                             $$ |          \\r\\n                             $$ |          \\r\\n                             \\\\__|          \\r\\n`;\n            let message = `Built with:\\n${skapi}Version: ${this.__version}\\n\\nFull Documentation: https://docs.skapi.com/skapi.md`;\n            console.log(message, `font-family: monospace; color:blue;`);\n            if (this.connection.group === 1) {\n                console.log(`%cSKAPI: THE SERVICE IS IN TRIAL MODE.`, `font-family: monospace; color:red;`);\n            }\n        }\n        return this.__version;\n    }\n\n    private log(n: string, v: any) {\n        if (this.__network_logs) {\n            if (v !== null && typeof v === 'object') {\n                try {\n                    // if it's not a browser runtime, print as a string to avoid [Object object] issue\n                    if (!isBrowserRuntime()) {\n                        v = JSON.stringify(v, null, 2);\n                    }\n                    else {\n                        v = JSON.parse(JSON.stringify(v));\n                    }\n                }\n                catch (err) {\n                    v = String(v);\n                }\n            }\n\n            else if (typeof v === 'string' && v.length > 100) {\n                v = v.substring(0, 100) + '...';\n            }\n\n            console.log(`%c${n}:`, 'color: blue;', v);\n        }\n    }\n\n    /**\n     * Fetches feed records visible to the current user with optional access-group filtering and pagination.\n     * @param params Request parameters.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<DatabaseResponse<RecordData>>.\n     */\n    @formHandler()\n    getFeed(params?: { access_group?: number; }, fetchOptions?: FetchOptions): Promise<DatabaseResponse<RecordData>> {\n        return getFeed.bind(this)(params, fetchOptions);\n    }\n\n    /**\n     * Closes an active WebRTC connection by cid or closes all active RTC connections.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<void>.\n     */\n    @formHandler()\n    closeRTC(params: { cid?: string; close_all?: boolean; }): Promise<void> {\n        return closeRTC.bind(this)(params);\n    }\n\n    /**\n     * Creates or joins a WebRTC session and returns an RTC connector for streaming events and controls.\n     * @param params Request parameters.\n     * @param callback Callback invoked for events or updates.\n     * @returns A promise that resolves to Promise<RTCConnector>.\n     */\n    @formHandler()\n    connectRTC(\n        params: RTCConnectorParams,\n        callback?: (e: RTCEvent) => void\n    ): Promise<RTCConnector> {\n        return connectRTC.bind(this)(params, callback);\n    }\n\n    /**\n     * Opens a realtime WebSocket connection and registers a callback for incoming realtime messages.\n     * @param callback Callback invoked for events or updates.\n     * @returns A promise that resolves to Promise<WebSocket>.\n     */\n    connectRealtime(callback: RealtimeCallback): Promise<WebSocket> {\n        return connectRealtime.bind(this)(callback);\n    }\n\n    /**\n     * Runs a spellcast operation and stores or returns generated spell data.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<string>.\n     */\n    @formHandler()\n    spellcast(params: {\n        spell: string,\n        name: string,\n        magic?: any\n    }): Promise<string> {\n        return spellcast.bind(this)(params)\n    }\n\n    /**\n     * Searches previously stored spell records by spell text or name. Defaults to 'spell' search if no search type is specified.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<DatabaseResponse<{ spell: string; magic?: any; name: string; }>>.\n     */\n    @formHandler()\n    getspell(params?: {\n        search?: 'spell' | 'name',\n        value?: string,\n    }): Promise<DatabaseResponse<{\n        spell: string;\n        name: string;\n        magic?: any;\n    }>> {\n        return getspell.bind(this)(params)\n    }\n\n    /**\n     * Sends a dopamine message payload and returns the previous message.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<string>.\n     */\n    @formHandler()\n    dopamine(params: {\n        message: string,\n        name: string\n    }): Promise<string> {\n        return dopamine.bind(this)(params)\n    }\n    /**\n     * Queries unique ID records by unique_id or condition filters.\n     * @param params Request parameters.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<DatabaseResponse<UniqueId>>.\n     */\n    @formHandler()\n    getUniqueId(params: Form<{\n        /** Unique ID */\n        unique_id?: string;\n        /** String query condition for tag name. */\n        condition?: Condition;\n    }>, fetchOptions?: FetchOptions): Promise<DatabaseResponse<UniqueId>> {\n        return getUniqueId.bind(this)(params, fetchOptions);\n    }\n\n    /**\n     * Resends an existing user invitation email to the target address.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<\"SUCCESS: Invitation has been re-sent. (User ID: xxx...)\">.\n     */\n    @formHandler()\n    resendInvitation(params: Form<{\n        email: string;\n        confirmation_url?: string;\n    }>): Promise<\"SUCCESS: Invitation has been re-sent. (User ID: xxx...)\"> {\n        return resendInvitation.bind(this)(params);\n    }\n\n    /**\n     * Cancels a pending invitation for the target email address.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<\"SUCCESS: Invitation has been canceled.\">.\n     */\n    @formHandler()\n    cancelInvitation(params: Form<{\n        email: string;\n    }>): Promise<\"SUCCESS: Invitation has been canceled.\"> {\n        return cancelInvitation.bind(this)(params);\n    }\n\n    /**\n     * Lists invitation records with optional email filtering and pagination.\n     * @param params Request parameters.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<DatabaseResponse<UserProfile>>.\n     */\n    @formHandler()\n    getInvitations(params: Form<{\n        email?: string;\n    }>, fetchOptions: FetchOptions): Promise<DatabaseResponse<UserProfile>> {\n        return getInvitations.bind(this)(params, fetchOptions);\n    }\n\n    /**\n     * Completes OpenID login and optionally merges the OpenID identity with an existing account.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<{ userProfile: UserProfile; openid: { [attribute: string]: string } }>.\n     */\n    @formHandler()\n    openIdLogin(params: { token: string; id: string; merge?: boolean | string[]; }): Promise<{ userProfile: UserProfile; openid: { [attribute: string]: string } }> {\n        return openIdLogin.bind(this)(params);\n    }\n\n    /**\n     * Logs in a user with externally issued id/access/refresh tokens.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<UserProfile>.\n     */\n    @formHandler()\n    loginWithToken(params: { idToken: string; accessToken?: string; refreshToken?: string; }): Promise<UserProfile> {\n        return loginWithToken.bind(this)(params);\n    }\n\n    // /**\n    //  * Creates or updates a newsletter group with its delivery restriction settings.\n    //  * @param params Request parameters.\n    //  * @returns A promise that resolves to Promise<\"SUCCESS: Your newsletter group has been registered.\">.\n    //  */\n    // @formHandler()\n    // registerNewsletterGroup(params: Form<{\n    //     group: string;\n    //     restriction: number;\n    // }>): Promise<\"SUCCESS: Your newsletter group has been registered.\"> {\n    //     return registerNewsletterGroup.bind(this)(params) as Promise<\"SUCCESS: Your newsletter group has been registered.\">;\n    // }\n    /**\n     * Sends a secure outbound request using a Skapi client secret key.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<any>.\n     */\n    @formHandler()\n    clientSecretRequest(params: {\n        url: string;\n        clientSecretName: string;\n        method: 'GET' | 'POST' | 'DELETE' | 'PUT';\n        headers?: { [key: string]: string };\n        data?: { [key: string]: any };\n        params?: { [key: string]: string };\n    }): Promise<any> {\n        return clientSecretRequest.bind(this)(params);\n    }\n\n    /**\n     * Consumes a one-time ticket and executes the ticketed request payload.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<any>.\n     */\n    @formHandler()\n    consumeTicket(params: {\n        ticket_id: string;\n        method: string; // GET | POST\n        auth?: boolean;\n        data?: {\n            [key: string]: any;\n        }\n    }): Promise<any> {\n        return consumeTicket.bind(this)(params);\n    }\n\n    /**\n     * Lists consumed tickets with optional filters and pagination.\n     * @param params Request parameters.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<DatabaseResponse<any[]>>.\n     */\n    @formHandler()\n    getConsumedTickets(params: { ticket_id?: string; }, fetchOptions: FetchOptions): Promise<DatabaseResponse<any[]>> {\n        return getConsumedTickets.bind(this)(params, fetchOptions);\n    }\n\n    /**\n     * Lists issued tickets with optional filters and pagination.\n     * @param params Request parameters.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<DatabaseResponse<any[]>>.\n     */\n    @formHandler()\n    getTickets(params: { ticket_id?: string; }, fetchOptions: FetchOptions): Promise<DatabaseResponse<any[]>> {\n        return getTickets.bind(this)(params, fetchOptions);\n    }\n\n    /**\n     * Closes the active realtime WebSocket connection.\n     * @returns A promise that resolves to Promise<void>.\n     */\n    closeRealtime(): Promise<void> {\n        return closeRealtime.bind(this)();\n    }\n\n    /**\n     * Fetches currently connected users in a realtime group.\n     * @param params Request parameters.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<DatabaseResponse<{ user_id: string; cid: string }[]>>.\n     */\n    @formHandler()\n    getRealtimeUsers(params: { group: string, user_id?: string }, fetchOptions?: FetchOptions): Promise<DatabaseResponse<{ user_id: string; cid: string }[]>> {\n        return getRealtimeUsers.bind(this)(params, fetchOptions);\n    }\n\n    /**\n     * Sends an inquiry email payload to the service contact channel.\n     * @param params Payload for the request.\n     * @returns A promise that resolves to Promise<\"SUCCESS: Inquiry has been sent.\">.\n     */\n    @formHandler()\n    sendInquiry(params: Form<{\n        name: string;\n        email: string;\n        subject: string;\n        message: string;\n    }>): Promise<\"SUCCESS: Inquiry has been sent.\"> {\n        return sendInquiry.bind(this)(params);\n    }\n\n    /**\n     * Blocks a user account by user_id.\n     * @param params Payload for the request.\n     * @returns A promise that resolves to Promise<\"SUCCESS: The user has been blocked.\">.\n     */\n    @formHandler()\n    blockAccount(params: { user_id: string }): Promise<\"SUCCESS: The user has been blocked.\"> {\n        return blockAccount.bind(this)(params);\n    }\n\n    /**\n     * Unblocks a previously blocked user account by user_id.\n     * @param params Payload for the request.\n     * @returns A promise that resolves to Promise<\"SUCCESS: The user has been unblocked.\">.\n     */\n    @formHandler()\n    unblockAccount(params: { user_id: string }): Promise<\"SUCCESS: The user has been unblocked.\"> {\n        return unblockAccount.bind(this)(params);\n    }\n\n    /**\n     * Deletes a user account by user_id.\n     * @param params Payload for the request.\n     * @returns A promise that resolves to Promise<\"SUCCESS: Account has been deleted.\">.\n     */\n    @formHandler()\n    deleteAccount(params: { user_id: string }): Promise<\"SUCCESS: Account has been deleted.\"> {\n        return deleteAccount.bind(this)(params);\n    }\n\n\n    /**\n     * Invites a user by email with optional attributes and invitation email options.\n     * @param params Payload for the request.\n     * @param options Optional behavior configuration.\n     * @returns A promise that resolves to Promise<'SUCCESS: Invitation has been sent.'>.\n     */\n    @formHandler()\n    inviteUser(\n        params: UserAttributes & { openid_id: string; access_group: number; },\n        options?: {\n            confirmation_url?: string;\n            email_subscription?: boolean;\n            template?: {\n                url: string;\n                subject: string;\n            }\n        }\n    ): Promise<'SUCCESS: Invitation has been sent.'> {\n        return inviteUser.bind(this)(params, options);\n    }\n\n    /**\n     * Creates a user account directly from admin context.\n     * @param params Payload for the request.\n     * @returns A promise that resolves to Promise<UserProfile & { email_admin: string; username: string; }>.\n     */\n    @formHandler()\n    createAccount(\n        params: UserAttributes & { password: string; access_group: number; }\n    ): Promise<UserProfile & { email_admin: string; username: string; }> {\n        return createAccount.bind(this)(params);\n    }\n\n    /**\n     * Updates a user's access_group level.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<'SUCCESS: Access has been granted to the user.'>.\n     */\n    @formHandler()\n    grantAccess(params: {\n        user_id: string;\n        access_group: number;\n    }): Promise<'SUCCESS: Access has been granted to the user.'> {\n        return grantAccess.bind(this)(params);\n    }\n\n    /**\n     * Lists realtime groups with optional search conditions and pagination.\n     * @param params Request parameters.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<DatabaseResponse<{ group: string; number_of_users: number; }>>.\n     */\n    @formHandler()\n    getRealtimeGroups(\n        params?: {\n            /** Index name to search. */\n            searchFor: 'group' | 'number_of_users';\n            /** Index value to search. */\n            value: string | number;\n            /** Search condition. */\n            condition?: '>' | '>=' | '=' | '<' | '<=' | '!=' | 'gt' | 'gte' | 'eq' | 'lt' | 'lte' | 'ne';\n            /** Range of search. */\n            range?: string | number;\n        } | null,\n        fetchOptions?: FetchOptions\n    ): Promise<DatabaseResponse<{ group: string; number_of_users: number; }>> {\n        return getRealtimeGroups.bind(this)(params, fetchOptions);\n    }\n    // /**\n    //  * Calls the newsletter group endpoint for administrative group operations.\n    //  * @param params Request parameters.\n    //  */\n    // @formHandler()\n    // newsletterGroupEndpoint(params) {\n    //     return newsletterGroupEndpoint.bind(this)(params);\n    // }\n    /**\n     * Sends realtime data to a user or group with optional push notification metadata.\n     * @param message Message payload to send.\n     * @param recipient Recipient user or group target.\n     * @param notification Optional notification payload.\n     * @returns A promise that resolves to Promise<{ type: 'success', message: 'Message sent.' }>.\n     */\n    @formHandler()\n    postRealtime(message: any, recipient: string, notification?: { config?: { always: boolean; }; title: string; body: string; }): Promise<{ type: 'success', message: 'Message sent.' }> {\n        return postRealtime.bind(this)(message, recipient, notification);\n    }\n\n    /**\n     * Joins the current connection to a realtime group or leaves group membership when null.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<{ type: 'success', message: string }>.\n     */\n    @formHandler()\n    joinRealtime(params: { group: string | null }): Promise<{ type: 'success', message: string }> {\n        return joinRealtime.bind(this)(params);\n    }\n\n    // /**\n    //  * Returns the active service connection object after initialization.\n    //  * @returns A promise that resolves to Promise<Connection>.\n    //  */\n    // private _getConnection(): Promise<Connection> {\n    //     return this.__connection;\n    // }\n\n    /**\n     * Retrieves the currently authenticated user profile, optionally refreshing token/session state.\n     * @param options Optional behavior configuration.\n     * @returns A promise that resolves to Promise<UserProfile | null>.\n     */\n    @formHandler()\n    getProfile(options?: { refreshToken: boolean; }): Promise<UserProfile | null> {\n        return getProfile.bind(this)(options);\n    }\n    /**\n     * Retrieves a file by URL with optional conversion mode, expiration, and progress handling.\n     * @param url Target URL.\n     * @param config Additional configuration options.\n     * @returns A promise that resolves to Promise<Blob | string | void | FileInfo>.\n     */\n    @formHandler()\n    getFile(\n        url: string, // cdn endpoint url https://xxxx.cloudfront.net/path/file\n        config?: {\n            dataType?: 'base64' | 'download' | 'endpoint' | 'blob' | 'text' | 'info'; // default 'download'\n            expires?: number; // uses url that expires. this option does not use the cdn (slow). can be used for private files. (does not work on public files).\n            progress?: ProgressCallback;\n        }\n    ): Promise<Blob | string | void | FileInfo> {\n        return getFile.bind(this)(url, config);\n    }\n    /**\n     * Executes authenticated secure API requests in single or batch mode.\n     * @param params Request parameters.\n     * @param url Target URL.\n     * @returns A promise that resolves to Promise<Response | Response[]>.\n     */\n    @formHandler()\n    secureRequest<Params = {\n        /** Request url */\n        url: string;\n        /** Request data */\n        data?: any;\n        /** requests are sync when true */\n        sync?: boolean;\n    }, Response = { response: any; statusCode: number; url: string; }>(params: Params[] | Form<Params>, url?: string): Promise<Response | Response[]> {\n        return secureRequest.bind(this)(params, url);\n    }\n    /**\n     * Returns a normalized response object for form-based handler flows.\n     * @returns A promise that resolves to Promise<any>.\n     */\n    @formHandler()\n    getFormResponse(): Promise<any> {\n        return getFormResponse.bind(this)();\n    }\n    /**\n     * Queries database records with filtering, sorting, and pagination options.\n     * @param query Query object used to filter results.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<DatabaseResponse<RecordData>>.\n     */\n    @formHandler()\n    getRecords(query: GetRecordQuery, fetchOptions?: FetchOptions): Promise<DatabaseResponse<RecordData>> {\n        return getRecords.bind(this)(query, fetchOptions);\n    }\n    /**\n     * Lists table metadata with optional table-name filters.\n     * @param query Query object used to filter results.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<DatabaseResponse<Table>>.\n     */\n    @formHandler()\n    getTables(\n        /** If null fetch all list of tables. */\n        query: {\n            table: string;\n            /** Condition operator of table name. */\n            condition?: Condition;\n        },\n        fetchOptions?: FetchOptions\n    ): Promise<DatabaseResponse<Table>> {\n        return getTables.bind(this)(query, fetchOptions);\n    }\n    /**\n     * Lists index metadata and aggregated index statistics for a table.\n     * @param query Query object used to filter results.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<DatabaseResponse<Index>>.\n     */\n    @formHandler()\n    getIndexes(\n        query: {\n            /** Table name */\n            table: string;\n            /** Index name. When period is at the end of name, querys nested index keys. */\n            index?: string;\n            /** Queries order by */\n            order?: {\n                /** Key name to order by. */\n                by: 'average_number' | 'total_number' | 'number_count' | 'average_bool' | 'total_bool' | 'bool_count' | 'string_count' | 'index_name';\n                /** Value to query. */\n                value?: number | boolean | string;\n                condition?: Condition;\n            };\n        },\n        fetchOptions?: FetchOptions\n    ): Promise<DatabaseResponse<Index>> { return getIndexes.bind(this)(query, fetchOptions); }\n    /**\n     * Lists tags used in a table with optional tag-name filtering.\n     * @param query Query object used to filter results.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<DatabaseResponse<Tag>>.\n     */\n    @formHandler()\n    getTags(\n        query: {\n            /** Table name */\n            table: string;\n            /** Tag name */\n            tag?: string;\n            /** String query condition for tag name. */\n            condition?: Condition;\n        },\n        fetchOptions?: FetchOptions\n    ): Promise<DatabaseResponse<Tag>> { return getTags.bind(this)(query, fetchOptions); }\n    /**\n     * Deletes records by query or record_id and returns deletion results.\n     * @param params Request parameters.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<string | DatabaseResponse<RecordData>>.\n     */\n    @formHandler()\n    deleteRecords(params: DelRecordQuery, fetchOptions?: FetchOptions): Promise<string | DatabaseResponse<RecordData>> { return deleteRecords.bind(this)(params, fetchOptions); }\n    /**\n     * Resends the signup confirmation email for the current pending account.\n     * @returns A promise that resolves to Promise<'SUCCESS: Signup confirmation e-mail has been sent.'>.\n     */\n    @formHandler()\n    resendSignupConfirmation(): Promise<'SUCCESS: Signup confirmation e-mail has been sent.'> {\n        return resendSignupConfirmation.bind(this)();\n    }\n    /**\n     * Sends an account recovery email and optionally sets a recovery redirect URL.\n     * @param redirect Redirect URL or false to disable redirect.\n     * @returns A promise that resolves to Promise<\"SUCCESS: Recovery e-mail has been sent.\">.\n     */\n    @formHandler()\n    recoverAccount(\n        /** Redirect url on confirmation success. */\n        redirect: boolean | string = false\n    ): Promise<\"SUCCESS: Recovery e-mail has been sent.\"> {\n        return recoverAccount.bind(this)(redirect);\n    }\n    /**\n     * Queries users by supported profile/search fields with pagination.\n     * @param params Request parameters.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<DatabaseResponse<UserPublic>>.\n     */\n    @formHandler()\n    getUsers(\n        params?: {\n            /** Index name to search. */\n            searchFor: 'user_id' | 'email' | 'phone_number' | 'locale' | 'name' | 'address' | 'gender' | 'birthdate' | 'subscribers' | 'timestamp' | 'approved';\n            /** Index value to search. */\n            value: string | number | boolean | string[];\n            /** Search condition. */\n            condition?: '>' | '>=' | '=' | '<' | '<=' | 'gt' | 'gte' | 'eq' | 'lt' | 'lte';\n            /** Range of search. */\n            range?: string | number | boolean;\n        },\n        fetchOptions?: FetchOptions): Promise<DatabaseResponse<UserPublic>> {\n        return getUsers.bind(this)(params, fetchOptions);\n    }\n    /**\n     * Disables the currently logged-in user account.\n     * @returns A promise that resolves to Promise<'SUCCESS: account has been disabled.'>.\n     */\n    @formHandler()\n    disableAccount(): Promise<'SUCCESS: account has been disabled.'> {\n        return disableAccount.bind(this)();\n    }\n    /**\n     * Returns the last verified email or reverts to it when revert is requested.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<string | UserProfile>.\n     */\n    @formHandler()\n    lastVerifiedEmail(params?: {\n        revert: boolean; // Reverts to last verified e-mail when true.\n    }): Promise<string | UserProfile> {\n        return lastVerifiedEmail.bind(this)(params);\n    }\n    /**\n     * Unsubscribes the user from a newsletter group.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<string>.\n     */\n    @formHandler()\n    unsubscribeNewsletter(\n        params: { group: number | 'public' | 'authorized' | null; }\n    ): Promise<string> {\n        return unsubscribeNewsletter.bind(this)(params);\n    }\n    // /**\n    //  * Sends an administrative newsletter request payload.\n    //  * @param params Request parameters.\n    //  */\n    // @formHandler()\n    // adminNewsletterRequest(params) {\n    //     return adminNewsletterRequest.bind(this)(params);\n    // }\n    /**\n     * Registers a web push subscription endpoint for notifications.\n     * @param endpoint Push subscription endpoint URL.\n     * @param keys Web Push key pair values.\n     * @returns A promise that resolves to Promise<'SUCCESS: Subscribed to receive notifications.'>.\n     */\n    @formHandler()\n    subscribeNotification(\n        endpoint: string,\n        keys: {\n            p256dh: string;\n            auth: string;\n        }\n    ): Promise<'SUCCESS: Subscribed to receive notifications.'> {\n        return subscribeNotification.bind(this)({ endpoint, keys });\n    }\n    /**\n     * Removes a registered web push subscription endpoint.\n     * @param endpoint Push subscription endpoint URL.\n     * @param keys Web Push key pair values.\n     * @returns A promise that resolves to Promise<'SUCCESS: Unsubscribed from notifications.'>.\n     */\n    @formHandler()\n    unsubscribeNotification(\n        endpoint: string,\n        keys: {\n            p256dh: string;\n            auth: string;\n        }\n    ): Promise<'SUCCESS: Unsubscribed from notifications.'> {\n        return unsubscribeNotification.bind(this)({ endpoint, keys });\n    }\n    /**\n     * Returns the VAPID public key required for browser push subscription setup.\n     * @returns A promise that resolves to Promise<{ VAPIDPublicKey: string }>.\n     */\n    @formHandler()\n    vapidPublicKey(): Promise<{ VAPIDPublicKey: string }> {\n        return vapidPublicKey.bind(this)();\n    }\n    /**\n     * Sends push notifications to one or more users.\n     * @param params Payload for the request.\n     * @param user_ids Parameter for this operation.\n     * @returns A promise that resolves to Promise<\"SUCCESS: Notification sent.\">.\n     */\n    @formHandler()\n    pushNotification(\n        params: {\n            title: string,\n            body: string\n        },\n        user_ids?: string | string[]\n    ): Promise<\"SUCCESS: Notification sent.\"> {\n        return pushNotification.bind(this)(params, user_ids);\n    }\n\n    /**\n     * Fetches newsletter delivery records with filters and pagination.\n     * @param params Request parameters.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<DatabaseResponse<Newsletter>>.\n     */\n    @formHandler()\n    getNewsletters(\n        params?: {\n            /**\n             * Search points.<br>\n             * 'message_id' and 'subject' value should be string.<br>\n             * Others numbers.\n             */\n            searchFor: 'message_id' | 'timestamp' | 'read' | 'complaint' | 'subject';\n            value: string | number;\n            range: string | number;\n            /**\n             * Defaults to '=',\n             * Condition does not work with range.\n             */\n            condition?: '>' | '>=' | '=' | '<' | '<=' | 'gt' | 'gte' | 'eq' | 'lt' | 'lte';\n            group: 'public' | 'authorized' | number;\n        },\n        fetchOptions?: FetchOptions\n    ): Promise<DatabaseResponse<Newsletter>> {\n        return getNewsletters.bind(this)(params, fetchOptions);\n    }\n    /**\n     * Gets newsletter subscription status for the requested groups.\n     * @param params Request parameters.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<{ active: boolean; timestamp: number; group: number; subscribed_email: string; }[]>.\n     */\n    @formHandler()\n    getNewsletterSubscription(params: { group?: number | 'public' | 'authorized'; },\n        fetchOptions?: FetchOptions): Promise<{\n            active: boolean;\n            timestamp: number;\n            group: number;\n            subscribed_email: string;\n        }[]> {\n        return getNewsletterSubscription.bind(this)(params, fetchOptions);\n    }\n    /**\n     * Requests a username change confirmation flow for the current user.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<'SUCCESS: confirmation e-mail has been sent.'>.\n     */\n    @formHandler()\n    requestUsernameChange(params: {\n        /** Redirect URL when user clicks on the link. */\n        redirect?: string;\n        /** username(e-mail) user wish to change to. */\n        username: string;\n    }): Promise<'SUCCESS: confirmation e-mail has been sent.'> { return requestUsernameChange.bind(this)(params); }\n    /**\n     * Grants users access to a private record.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<string>.\n     */\n    @formHandler()\n    grantPrivateRecordAccess(params: {\n        record_id: string;\n        user_id: string | string[];\n    }): Promise<string> { return grantPrivateRecordAccess.bind(this)(params); }\n    /**\n     * Removes previously granted private record access.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<string>.\n     */\n    @formHandler()\n    removePrivateRecordAccess(params: {\n        record_id: string;\n        user_id: string | string[];\n    }): Promise<string> {\n        return removePrivateRecordAccess.bind(this)(params);\n    }\n    /**\n     * Lists current private record access grants.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<DatabaseResponse<{ record_id: string; user_id: string; }>>.\n     */\n    @formHandler()\n    listPrivateRecordAccess(params: {\n        record_id?: string;\n        user_id?: string | string[];\n    }): Promise<DatabaseResponse<{ record_id: string; user_id: string; }>> { return listPrivateRecordAccess.bind(this)(params); }\n    /**\n     * Requests a temporary access key for reading a private record.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<string>.\n     */\n    @formHandler()\n    requestPrivateRecordAccessKey(params: { record_id: string; reference_id?: string; }): Promise<string> {\n        return requestPrivateRecordAccessKey.bind(this)(params);\n    }\n    /**\n     * Deletes uploaded files by endpoint list.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<RecordData[]>.\n     */\n    @formHandler()\n    deleteFiles(params: {\n        endpoints: string | string[], // bin file endpoints\n    }): Promise<RecordData[]> {\n        return deleteFiles.bind(this)(params);\n    }\n    /**\n     * Uploads files to an existing record and returns completed and failed results.\n     * @param fileList Files or form event containing files.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<{ completed: File[], failed: File[], bin_endpoints: string[] }>.\n     */\n    @formHandler()\n    uploadFiles(\n        fileList: FormData | HTMLFormElement | SubmitEvent,\n        params: {\n            record_id: string; // Record ID of a record to upload files to.\n            progress?: ProgressCallback;\n        }\n    ): Promise<{ completed: File[], failed: File[], bin_endpoints: string[] }> { return uploadFiles.bind(this)(fileList, params); }\n    /**\n     * Calls the mock endpoint for testing request and error handling flows.\n     * @param data Data payload for the request.\n     * @param options Optional behavior configuration.\n     * @returns A promise that resolves to Promise<{ [key: string]: any }>.\n     */\n    @formHandler()\n    mock(\n        data: Form<any | { raise: 'ERR_INVALID_REQUEST' | 'ERR_INVALID_PARAMETER' | 'SOMETHING_WENT_WRONG' | 'ERR_EXISTS' | 'ERR_NOT_EXISTS'; }>,\n        options?: {\n            auth?: boolean;\n            method?: string;\n            responseType?: 'blob' | 'json' | 'text' | 'arrayBuffer' | 'formData' | 'document';\n            contentType?: string;\n            progress?: ProgressCallback;\n        }): Promise<{ [key: string]: any }> { return mock.bind(this)(data, options); }\n    /**\n     * Authenticates a user with email/username and password.\n     * @param params Payload for the request.\n     * @returns A promise that resolves to Promise<UserProfile>.\n     */\n    @formHandler({ preventMultipleCalls: true })\n    login(\n        params: Form<{\n            /** if given, username will be used instead of email. */\n            username?: string;\n            /** E-Mail for signin. 64 character max. */\n            email: string;\n            /** Password for signin. Should be at least 6 characters. */\n            password: string;\n        }>): Promise<UserProfile> { return login.bind(this)(params); }\n    /**\n     * Logs out the current user session (optionally globally).\n     * @param params Payload for the request.\n     * @returns A promise that resolves to Promise<'SUCCESS: The user has been logged out.'>.\n     */\n    @formHandler()\n    logout(params?: Form<{ global: boolean; }>): Promise<'SUCCESS: The user has been logged out.'> { return logout.bind(this)(params); }\n\n    /**\n     * Creates a new user account with optional signup and login behavior settings.\n     * @param params Payload for the request.\n     * @param option Optional behavior configuration.\n     * @returns A promise that resolves to Promise<UserProfile | \"SUCCESS: The account has been created. User's signup confirmation is required.\" | 'SUCCESS: The account has been created.'>.\n     */\n    @formHandler({ preventMultipleCalls: true })\n    signup(\n        params: Form<UserAttributes & { password: String; username?: string; }>,\n        option?: {\n            /**\n             * When true, the service will send out confirmation E-Mail.\n             * User will not be able to signin to their account unless they have confirm their email.\n             * Parameter also accepts URL string for user to be taken to when clicked on confirmation link.\n             * Default is false.\n             */\n            signup_confirmation?: boolean | string;\n            /**\n             * When true, user will be subscribed to the service newsletter (group 1) once they are signed up.\n             * User's signup confirmation is required for this parameter.\n             * Default is false.\n             */\n            email_subscription?: boolean;\n            /**\n             * Automatically login to account after signup. Will not work if signup confirmation is required.\n             */\n            login?: boolean;\n        }): Promise<UserProfile | \"SUCCESS: The account has been created. User's signup confirmation is required.\" | 'SUCCESS: The account has been created.'> {\n        return signup.bind(this)(params, option);\n    }\n\n    /**\n     * Resets a password using email, verification code, and new password.\n     * @param params Payload for the request.\n     * @returns A promise that resolves to Promise<\"SUCCESS: New password has been set.\">.\n     */\n    @formHandler({ preventMultipleCalls: true })\n    resetPassword(params: Form<{\n        /** Signin E-Mail */\n        email: string;\n        /** The verification code user has received. */\n        code: string | number;\n        /** New password to set. Verification code is required. */\n        new_password: string;\n    }>): Promise<\"SUCCESS: New password has been set.\"> { return resetPassword.bind(this)(params); }\n    /**\n     * Verifies the user email address with a confirmation code.\n     * @param params Payload for the request.\n     * @returns A promise that resolves to Promise<string>.\n     */\n    @formHandler({ preventMultipleCalls: true })\n    verifyEmail(params?: Form<{ code: string; }>): Promise<string> {\n        // 'SUCCESS: Verification code has been sent.' | 'SUCCESS: \"email\" is verified.'\n        return verifyEmail.bind(this)(params);\n    }\n    /**\n     * Verifies the user phone number with a confirmation code.\n     * @param params Payload for the request.\n     * @returns A promise that resolves to Promise<string>.\n     */\n    @formHandler({ preventMultipleCalls: true })\n    verifyPhoneNumber(params?: Form<{ code: string; }>): Promise<string> {\n        // 'SUCCESS: Verification code has been sent.' | 'SUCCESS: \"phone_number\" is verified.'\n        return verifyPhoneNumber.bind(this)(params);\n    }\n    /**\n     * Sends a password reset verification code to the user email.\n     * @param params Payload for the request.\n     * @returns A promise that resolves to Promise<\"SUCCESS: Verification code has been sent.\">.\n     */\n    @formHandler({ preventMultipleCalls: true })\n    forgotPassword(\n        params: Form<{\n            /** Signin E-Mail. */\n            email: string;\n        }>): Promise<\"SUCCESS: Verification code has been sent.\"> {\n        return forgotPassword.bind(this)(params);\n    }\n    /**\n     * Changes password for the authenticated user.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<'SUCCESS: Password has been changed.'>.\n     */\n    @formHandler({ preventMultipleCalls: true })\n    changePassword(params: {\n        new_password: string;\n        current_password: string;\n    }): Promise<'SUCCESS: Password has been changed.'> { return changePassword.bind(this)(params); }\n    /**\n     * Updates profile attributes for the authenticated user.\n     * @param params Payload for the request.\n     * @returns A promise that resolves to Promise<UserProfile>.\n     */\n    @formHandler({ preventMultipleCalls: true })\n    updateProfile(params: Form<UserAttributes>): Promise<UserProfile> { return updateProfile.bind(this)(params); }\n    /**\n     * Creates or updates a database record with optional file uploads.\n     * @param params Payload for the request.\n     * @param config Additional configuration options.\n     * @param files File list to process.\n     * @returns A promise that resolves to Promise<RecordData>.\n     */\n    @formHandler()\n    postRecord(\n        params: Form<Record<string, any>> | null | undefined,\n        config: PostRecordConfig,\n        files?: { name: string, file: File }[]\n    ): Promise<RecordData> { return postRecord.bind(this)(params, config, files); }\n    /**\n     * Fetches subscriber/subscription relationships with filters and pagination.\n     * @param params Request parameters.\n     * @param fetchOptions Pagination and fetch behavior options.\n     * @returns A promise that resolves to Promise<DatabaseResponse<Subscription>>.\n     */\n    @formHandler()\n    getSubscriptions(\n        params: {\n            /** Subscribers user id. */\n            subscriber?: string;\n            /** User ID of the subscription. User id that subscriber has subscribed to. */\n            subscription?: string;\n            /** Fetch blocked subscription when True */\n            blocked?: boolean;\n        },\n        fetchOptions?: FetchOptions\n    ): Promise<DatabaseResponse<Subscription>> {\n        return getSubscriptions.bind(this)(params, fetchOptions);\n    }\n    /**\n     * Subscribes to another user with optional feed/notification/email preferences.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<Subscription>.\n     */\n    @formHandler()\n    subscribe(params: { user_id: string; get_feed?: boolean; get_notified?: boolean; get_email?: boolean; }): Promise<Subscription> {\n        return subscribe.bind(this)(params);\n    }\n    /**\n     * Unsubscribes from another user.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<'SUCCESS: The user has unsubscribed.'>.\n     */\n    @formHandler()\n    unsubscribe(params: { user_id: string; }): Promise<'SUCCESS: The user has unsubscribed.'> {\n        return unsubscribe.bind(this)(params);\n    }\n    /**\n     * Blocks a subscriber user_id.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<'SUCCESS: Blocked user ID \"xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx\".'>.\n     */\n    @formHandler()\n    blockSubscriber(params: { user_id: string; }): Promise<'SUCCESS: Blocked user ID \"xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx\".'> {\n        return blockSubscriber.bind(this)(params);\n    }\n    /**\n     * Unblocks a previously blocked subscriber user_id.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<'SUCCESS: Unblocked user ID \"xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx\".'>.\n     */\n    @formHandler()\n    unblockSubscriber(params: { user_id: string; }): Promise<'SUCCESS: Unblocked user ID \"xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx\".'> {\n        return unblockSubscriber.bind(this)(params);\n    }\n    /**\n     * Subscribes an email/user to a newsletter group with optional redirect flow.\n     * @param params Request parameters.\n     * @returns A promise that resolves to Promise<string>.\n     */\n    @formHandler()\n    subscribeNewsletter(\n        params: Form<{\n            email?: string;\n            group: number | 'public' | 'authorized' | 'admin';\n            redirect?: string;\n        }>\n    ): Promise<string> {\n        return subscribeNewsletter.bind(this)(params);\n    }\n\n    bulkPostRecords(config: PostRecordConfig): Promise<RecordData[]> {\n        return bulkPostRecords.bind(this)(config);\n    }\n}","export type Condition = 'gt' | 'gte' | 'lt' | 'lte' | 'eq' | '>' | '>=' | '<' | '<=' | '=';\n\n\nexport type RTCReceiverParams = {\n    ice?: string;\n    media?: {\n        video: boolean;\n        audio: boolean;\n    } | MediaStream | MediaStreamConstraints;\n}\n\nexport type RTCConnectorParams = {\n    cid: string;\n    ice?: string;\n    media?: {\n        video: boolean;\n        audio: boolean;\n    } | MediaStream | MediaStreamConstraints;\n    channels?: Array<RTCDataChannelInit | 'text-chat' | 'file-transfer' | 'video-chat' | 'voice-chat' | 'gaming'>;\n}\n\nexport type RTCConnector = {\n    hangup: () => void;\n    connection: Promise<RTCResolved>;\n}\n\nexport type RTCResolved = {\n    target: RTCPeerConnection;\n    channels: {\n        [protocol: string]: RTCDataChannel\n    };\n    hangup: () => void;\n    media: MediaStream;\n}\n\nexport type RTCEvent = {\n    type: 'track' | 'connectionstatechange' | 'close' | 'message' | 'open' | 'bufferedamountlow' | 'error' | 'icecandidate' | 'icecandidateend' | 'icegatheringstatechange' | 'negotiationneeded' | 'signalingstatechange';\n    [key: string]: any;\n}\n\nexport type WebSocketMessage = {\n    type: 'message' | 'error' | 'success' | 'close' | 'notice' | 'private' | 'reconnect' | 'rtc:incoming' | 'rtc:closed';\n    message?: any;\n    connectRTC?: (params: RTCReceiverParams, callback: (e: RTCEvent) => void) => Promise<RTCResolved>;\n    hangup?: () => void; // Reject incoming RTC connection.\n    sender?: string; // user_id of the sender\n    sender_cid?: string; // scid of the sender\n    sender_rid?: string; // group of the sender\n    code?: 'USER_LEFT' | 'USER_DISCONNECTED' | 'USER_JOINED' | null; // code for notice messeges\n}\n\nexport type RealtimeCallback = (rt: WebSocketMessage) => void;\n\nexport type DelRecordQuery = GetRecordQuery & {\n    unique_id?: string | string[];\n    record_id?: string | string[];\n};\n\nexport type GetRecordQuery = {\n    unique_id?: string; // When unique_id is given, it will fetch the record with the given unique_id.\n    record_id?: string; // When record_id is given, it will fetch the record with the given record_id. This overrides all other parameters.\n\n    /** Table name not required when \"record_id\" is given.*/\n    table?: {\n        /** Max 128 chars. Blocks: / ! * #, control chars, and sentinel 􏿿. */\n        name: string;\n        /** Number range: 0 ~ 99. Default: 'public' */\n        access_group?: number | 'private' | 'public' | 'authorized' | 'admin';\n        /** User ID of subscription */\n        subscription?: string;\n    };\n\n    reference?: string // Referenced record ID or unique ID. If user ID is given, it will fetch records that are uploaded by the user.\n\n    /** Index condition and range cannot be used simultaneously.*/\n    index?: {\n        /** Custom names: max 128 chars, cannot start with \"$\", blocks / ! * #, control chars, and sentinel 􏿿. Reserved names: $uploaded, $updated, $referenced_count, $user_id. */\n        name: string | '$updated' | '$uploaded' | '$referenced_count' | '$user_id';\n        /** String value max 256 chars. Allows punctuation (including / ! * #). Blocks control chars and sentinel 􏿿. */\n        value: string | number | boolean;\n        condition?: Condition;\n        range?: string | number | boolean;\n    };\n    tag?: string;\n}\n\nexport type PostRecordConfig = {\n    record_id?: string; // when record_id is given, it will update the record with the given record_id. If record_id is not given, it will create a new record.\n    unique_id?: string | null; // You can set unique_id to the record with the given unique_id. Null will remove unique_id from the record.\n    readonly?: boolean; // When true, record cannot be updated or deleted.\n\n    /** Table name not required when \"record_id\" is given.*/\n    table?: {\n        /** Max 128 chars. Blocks: / ! * #, control chars, and sentinel 􏿿. */\n        name?: string;\n        /** Number range: 0 ~ 99. Default: 'public' */\n        access_group?: number | 'private' | 'public' | 'authorized' | 'admin';\n\n        /** When true, Record will be only accessible for subscribed users. */\n        subscription?: {\n            is_subscription_record?: boolean; // When true, this record is a subscription record.\n            upload_to_feed?: boolean; // When true, record will be uploaded to the feed of the subscribers.\n            notify_subscribers?: boolean; // When true, subscribers will receive notification when the record is uploaded.\n            feed_referencing_records?: boolean; // When true, records referencing this record will be included to the subscribers feed.\n            notify_referencing_records?: boolean; // When true, records referencing this record will be notified to subscribers.\n        } | null; // When null, it will remove all subscription settings from the record.\n    };\n\n    source?: {\n        referencing_limit?: number; // Default: null (Infinite)\n        prevent_multiple_referencing?: boolean; // If true, a single user can reference this record only once.\n        can_remove_referencing_records?: boolean; // When true, owner of the record can remove any record that are referencing this record. Also when this record is deleted, all the record referencing this record will be deleted.\n        only_granted_can_reference?: boolean; // When true, only the user who has granted private access to the record can reference this record.\n        /** Index restrictions for referencing records. null removes all restrictions. */\n        referencing_index_restrictions?: {\n            /** Not allowed: White space, special characters. Allowed: Alphanumeric, Periods. */\n            name: string; // Allowed index name\n            /** Not allowed: Periods, special characters. Allowed: Alphanumeric, White space. */\n            value?: string | number | boolean; // Allowed index value\n            range?: string | number | boolean; // Allowed index range\n            condition?: 'gt' | 'gte' | 'lt' | 'lte' | 'eq' | 'ne' | '>' | '>=' | '<' | '<=' | '=' | '!='; // Allowed index value condition\n        }[] | null;\n        allow_granted_to_grant_others?: boolean; // When true, the user who has granted private access to the record can grant access to other users.\n    };\n\n    /** Can be record ID or unique ID */\n    reference?: string | null; // When null, it will remove reference from the record.\n\n    /** null removes index */\n    index?: {\n        /** Max 128 chars, cannot start with \"$\", blocks / ! * #, control chars, and sentinel 􏿿. */\n        name: string;\n        /** String value max 256 chars. Allows punctuation (including / ! * #). Blocks control chars and sentinel 􏿿. */\n        value: string | number | boolean;\n    } | null;\n\n    tags?: string[] | null; // null removes all tags. each tag max 64 chars, blocks / ! * #, control chars, and sentinel 􏿿.\n    remove_bin?: BinaryFile[] | string[] | null; // Removes bin data from the record. When null, it will remove all bin data.\n    progress?: ProgressCallback; // Callback for database request progress. Useful when building progress bar.\n    reference_private_key?: string; // When referencing a record that has private access, you can provide the private key of the referenced record to pass the access check. This is only required when the referenced record has private access and the user does not have access to the record through subscription or granted access.\n}\n\nexport type BinaryFile = {\n    access_group: number | 'private' | 'public' | 'authorized' | 'admin';\n    filename: string;\n    url: string;\n    path: string;\n    size: number;\n    uploaded: number;\n    getFile: (dataType?: 'base64' | 'download' | 'endpoint' | 'blob' | 'text' | 'info', progress?: ProgressCallback) => Promise<Blob | string | void | FileInfo>;\n}\n\nexport type RecordData = {\n    record_id: string;\n    unique_id?: string;\n    user_id: string;\n    updated: number;\n    uploaded: number;\n    referenced_count: number;\n\n    table: {\n        name: string;\n        /** Number range: 0 ~ 99 */\n        access_group: number | 'private' | 'public' | 'authorized' | 'admin';\n        /** User ID of subscription */\n        subscription?: {\n            upload_to_feed: boolean; // When true, record will be uploaded to the feed of the subscribers.\n            notify_subscribers: boolean; // When true, subscribers will receive notification when the record is uploaded.\n            feed_referencing_records: boolean; // When true, records referencing this record will be included to the subscribers feed.\n            notify_referencing_records: boolean; // When true, records referencing this record will be notified to subscribers.\n        };\n    };\n    source: {\n        referencing_limit: number; // Default: null (Infinite)\n        prevent_multiple_referencing: boolean; // If true, a single user can reference this record only once.\n        can_remove_referencing_records: boolean; // When true, owner of the record can remove any record that are referencing this record. Also when this record is deleted, all the record referencing this record will be deleted.\n        only_granted_can_reference: boolean; // When true, only the user who has granted private access to the record can reference this record.\n        referencing_index_restrictions?: {\n            name: string; // Allowed index name\n            value?: string | number | boolean; // Allowed index value\n            range?: string | number | boolean; // Allowed index range\n            condition?: 'gt' | 'gte' | 'lt' | 'lte' | 'eq' | 'ne' | '>' | '>=' | '<' | '<=' | '=' | '!='; // Allowed index value condition\n        }[];\n    };\n    reference?: string; // record id of the referenced record.\n    index?: {\n        name: string;\n        value: string | number | boolean;\n    };\n    data?: Record<string, any>;\n    tags?: string[];\n    bin: { [key: string]: BinaryFile[] };\n    ip: string;\n    readonly: boolean;\n}\n\nexport type Connection = {\n    /** User's locale */\n    locale: string;\n    user_agent: string;\n    /** Connected user's IP address */\n    ip: string;\n    /** Service group */\n    group: number;\n    /** Service name */\n    service_name: string;\n    /** Service options */\n    opt: {\n        freeze_database: boolean;\n        prevent_inquiry: boolean;\n        prevent_signup: boolean;\n    }\n}\n\nexport type Form<T> = HTMLFormElement | FormData | SubmitEvent | T;\n\nexport type Newsletter = {\n    /** Newsletter id */\n    message_id: string;\n    /** Time sent out */\n    timestamp: number;\n    /** Number of complaints */\n    complaint: number;\n    /** Number of read */\n    read: number;\n    /** Subject */\n    subject: string;\n    /**\n     * Number of bounced.<br>\n     * When e-mail address is bounced, skapi no longer sends e-mail to the bounced address.\n     */\n    bounced: string;\n    /**\n     * Url of the message html.\n     */\n    url: string;\n    /** Number users delivered */\n    delivered: number;\n}\n\nexport type UserAttributes = {\n    /** User's name */\n    name?: string;\n    /**\n     * User's E-Mail for signin.<br>\n     * 64 character max.<br>\n     * When E-Mail is changed, E-Mail verified state will be changed to false.\n     * E-Mail is only visible to others when set to public.\n     * E-Mail should be verified to set to public.\n     * */\n    email?: string;\n    /**\n     * User's phone number. Format: \"+0012341234\"<br>\n     * When phone number is changed, phone number verified state will be changed to false.\n     * Phone number is only visible to others when set to public.\n     * Phone number should be verified to set to public.\n     */\n    phone_number?: string;\n    /** User's address, only visible to others when set to public. */\n    address?: string | {\n        /**\n         * Full mailing address, formatted for display or use on a mailing label. This field MAY contain multiple lines, separated by newlines. Newlines can be represented either as a carriage return/line feed pair (\"\\r\\n\") or as a single line feed character (\"\\n\").\n         * street_address\n         * Full street address component, which MAY include house number, street name, Post Office Box, and multi-line extended street address information. This field MAY contain multiple lines, separated by newlines. Newlines can be represented either as a carriage return/line feed pair (\"\\r\\n\") or as a single line feed character (\"\\n\").\n        */\n        formatted: string;\n        // City or locality component.\n        locality: string;\n        // State, province, prefecture, or region component.\n        region: string;\n        // Zip code or postal code component.\n        postal_code: string;\n        // Country name component.\n        country: string;\n    };\n    /**\n     * User's gender. Can be \"female\" and \"male\".\n     * Other values may be used when neither of the defined values are applicable.\n     * Only visible to others when set to public.\n     */\n    gender?: string;\n    /** User's birthdate. String format: \"1969-07-16\", only visible to others when set to public.*/\n    birthdate?: string;\n\n    /** Additional string value that can be used freely. This is only accessible to the owner of the account and the admins. */\n    misc?: string;\n    picture?: string;\n    profile?: string;\n    website?: string;\n    nickname?: string;\n\n    /** User's E-Mail is public when true. E-Mail should be verified. */\n    email_public?: boolean;\n    /** User's phone number is public when true. Phone number should be verified. */\n    phone_number_public?: boolean;\n    /** User's address is public when true. */\n    address_public?: boolean;\n    /** User's gender is public when true. */\n    gender_public?: boolean;\n    /** User's birthdate is public when true. */\n    birthdate_public?: boolean;\n}\n\nexport type UserProfile = {\n    /** Service id of the user account. */\n    service: string;\n    /** User ID of the service owner. */\n    owner: string;\n    /** Access level of the user's account. */\n    access_group: number;\n    /** User's ID. */\n    user_id: string;\n    /** Country code of where user first signed up from. */\n    locale: string;\n    /**\n    Account approval info and timestamp.\n    Comes with string with the following format: \"{approver}:{approved | suspended}:{approved_timestamp}\"\n    \n    {approver} is who approved the account:\n        [by_master] is when account approval is done manually from skapi admin panel,\n        [by_admin] is when approval is done by the admin account with api call within your service.\n        [by_skapi] is when account approval is automatically done.\n        Open ID logger ID will be the value if the user is logged with openIdLogin()\n        This timestamp is generated when the user confirms their signup, or recovers their disabled account.\n    \n    {approved | suspended}\n        [approved] is when the account is approved.\n        [suspended] is when the account is blocked by the admin or the master.\n    \n    {approved_timestamp} is the timestamp when the account is approved or suspended.\n\n     */\n    approved: string;\n    /** Last login timestamp(Seconds). */\n    log: number;\n    /** Shows true when user has verified their E-Mail. */\n    email_verified?: boolean;\n    /** Shows true when user has verified their phone number. */\n    phone_number_verified?: boolean;\n        /** User's E-Mail is public when true. E-Mail should be verified. */\n    email_public?: boolean;\n    /** User's phone number is public when true. Phone number should be verified. */\n    phone_number_public?: boolean;\n    /** User's address is public when true. */\n    address_public?: boolean;\n    /** User's gender is public when true. */\n    gender_public?: boolean;\n    /** User's birthdate is public when true. */\n    birthdate_public?: boolean;\n\n    /** User's name */\n    name?: string;\n    /**\n     * User's E-Mail for signin.<br>\n     * 64 character max.<br>\n     * When E-Mail is changed, E-Mail verified state will be changed to false.\n     * E-Mail is only visible to others when set to public.\n     * E-Mail should be verified to set to public.\n     * */\n    email?: string;\n    /**\n     * User's phone number. Format: \"+0012341234\"<br>\n     * When phone number is changed, phone number verified state will be changed to false.\n     * Phone number is only visible to others when set to public.\n     * Phone number should be verified to set to public.\n     */\n    phone_number?: string;\n    /** User's address, only visible to others when set to public. */\n    address?: string | {\n        /**\n         * Full mailing address, formatted for display or use on a mailing label. This field MAY contain multiple lines, separated by newlines. Newlines can be represented either as a carriage return/line feed pair (\"\\r\\n\") or as a single line feed character (\"\\n\").\n         * street_address\n         * Full street address component, which MAY include house number, street name, Post Office Box, and multi-line extended street address information. This field MAY contain multiple lines, separated by newlines. Newlines can be represented either as a carriage return/line feed pair (\"\\r\\n\") or as a single line feed character (\"\\n\").\n        */\n        formatted: string;\n        // City or locality component.\n        locality: string;\n        // State, province, prefecture, or region component.\n        region: string;\n        // Zip code or postal code component.\n        postal_code: string;\n        // Country name component.\n        country: string;\n    };\n    /**\n     * User's gender. Can be \"female\" and \"male\".\n     * Other values may be used when neither of the defined values are applicable.\n     * Only visible to others when set to public.\n     */\n    gender?: string;\n    /** User's birthdate. String format: \"1969-07-16\", only visible to others when set to public.*/\n    birthdate?: string;\n\n    /** Additional string value that can be used freely. This is only accessible to the owner of the account and the admins. */\n    misc?: string;\n    picture?: string;\n    profile?: string;\n    website?: string;\n    nickname?: string;\n};\n\nexport type UserPublic = {\n    /** Access level of the user's account. */\n    access_group: number;\n    /** User's ID. */\n    user_id: string;\n    /** Country code of where user first signed up from. */\n    locale: string;\n    /**\n    Account approval info and timestamp.\n    Comes with string with the following format: \"{approver}:{approved | suspended}:{approved_timestamp}\"\n    \n    {approver} is who approved the account:\n        [by_master] is when account approval is done manually from skapi admin panel,\n        [by_admin] is when approval is done by the admin account with api call within your service.\n        [by_skapi] is when account approval is automatically done.\n        Open ID logger ID will be the value if the user is logged with openIdLogin()\n        This timestamp is generated when the user confirms their signup, or recovers their disabled account.\n    \n    {approved | suspended}\n        [approved] is when the account is approved.\n        [suspended] is when the account is blocked by the admin or the master.\n    \n    {approved_timestamp} is the timestamp when the account is approved or suspended.\n\n     */\n    approved: string;\n    /** Account created timestamp(13 digit milliseconds). */\n    timestamp: number;\n    /** Last login timestamp(Seconds). */\n    log: number;\n    /** Number of the user's subscribers. */\n    subscribers: number;\n    /** Number of subscription the user has made */\n    subscribed: number;\n    /** Number of the records the user have created. */\n    records: number;\n\n    /** User's name */\n    name?: string;\n    /**\n     * User's E-Mail for signin.<br>\n     * 64 character max.<br>\n     * When E-Mail is changed, E-Mail verified state will be changed to false.\n     * E-Mail is only visible to others when set to public.\n     * E-Mail should be verified to set to public.\n     * */\n    email?: string;\n    /**\n     * User's phone number. Format: \"+0012341234\"<br>\n     * When phone number is changed, phone number verified state will be changed to false.\n     * Phone number is only visible to others when set to public.\n     * Phone number should be verified to set to public.\n     */\n    phone_number?: string;\n    /** User's address, only visible to others when set to public. */\n    address?: string | {\n        /**\n         * Full mailing address, formatted for display or use on a mailing label. This field MAY contain multiple lines, separated by newlines. Newlines can be represented either as a carriage return/line feed pair (\"\\r\\n\") or as a single line feed character (\"\\n\").\n         * street_address\n         * Full street address component, which MAY include house number, street name, Post Office Box, and multi-line extended street address information. This field MAY contain multiple lines, separated by newlines. Newlines can be represented either as a carriage return/line feed pair (\"\\r\\n\") or as a single line feed character (\"\\n\").\n        */\n        formatted: string;\n        // City or locality component.\n        locality: string;\n        // State, province, prefecture, or region component.\n        region: string;\n        // Zip code or postal code component.\n        postal_code: string;\n        // Country name component.\n        country: string;\n    };\n    /**\n     * User's gender. Can be \"female\" and \"male\".\n     * Other values may be used when neither of the defined values are applicable.\n     * Only visible to others when set to public.\n     */\n    gender?: string;\n    /** User's birthdate. String format: \"1969-07-16\", only visible to others when set to public.*/\n    birthdate?: string;\n\n    picture?: string;\n    profile?: string;\n    website?: string;\n    nickname?: string;\n};\n\nexport type ProgressCallback = (e: {\n    status: 'upload' | 'download';\n    progress: number; // 0 ~ 100, number of percent completed.\n    loaded: number; // Number of bytes loaded.\n    total: number; // Total number of bytes to be loaded.\n    currentFile?: File, // Only for uploadFiles()\n    completed?: File[]; // Only for uploadFiles()\n    failed?: File[]; // Only for uploadFiles()\n    abort: () => void; // Aborts current data transfer. When abort is triggered during the FileList is on trasmit, it will continue to next file.\n}) => void;\n\nexport type FetchOptions = {\n    /** Maximum number of records to fetch per call */\n    limit?: number;\n    /** Fetch next batch of data. Will return empty list if there is nothing more to fetch. */\n    fetchMore?: boolean;\n    /** Result in ascending order if true, decending when false. */\n    ascending?: boolean;\n    /** Start key to be used to query from the certain batch of fetch. */\n    startKey?: { [key: string]: any; };\n    /** Callback for database request progress. Useful when building progress bar. */\n    progress?: ProgressCallback;\n}\n\nexport type DatabaseResponse<T> = {\n    list: T[];\n    startKey: { [key: string]: any; } | 'end';\n    endOfList: boolean;\n    startKeyHistory: string[];\n}\n\nexport type FileInfo = {\n    url: string;\n    filename: string;\n    access_group: number | 'private' | 'public' | 'authorized';\n    filesize: number;\n    record_id: string;\n    uploader: string;\n    uploaded: number;\n    fileKey: string;\n}\n\nexport type ConnectionInfo = {\n    user_ip: string;\n    user_agent: string;\n    user_location: string;\n    service_name: string;\n    version: string;\n};\n\nexport type Table = {\n    table: string;\n    number_of_records: string;\n    size: number;\n}\n\nexport type Index = {\n    table: string;\n    index: string;\n    number_of_records: number;\n    string_count: number;\n    number_count: number;\n    boolean_count: number;\n    total_number: number;\n    total_bool: number;\n    average_number: number;\n    average_bool: number;\n}\n\nexport type Tag = {\n    table: string;\n    tag: string;\n    number_of_records: number;\n}\n\nexport type UniqueId = {\n    unique_id: string;\n    record_id: string;\n}\n\nexport type Subscription = {\n    subscriber: string;\n    subscription: string;\n    timestamp: number;\n    blocked: boolean;\n    get_feed: boolean;\n    get_notified: boolean;\n    get_email: boolean;\n}"]}