feat: setMiddlewareOptions function
All checks were successful
Docs / build (push) Successful in 2m22s
All checks were successful
Docs / build (push) Successful in 2m22s
This commit is contained in:
parent
3f6a7eeb6a
commit
2970738c89
2 changed files with 28 additions and 9 deletions
|
@ -82,7 +82,8 @@ export async function setupMonaco() {
|
||||||
extraLibs.push({
|
extraLibs.push({
|
||||||
content:
|
content:
|
||||||
'declare const tg: import("@mtcute/web").TelegramClient;\n'
|
'declare const tg: import("@mtcute/web").TelegramClient;\n'
|
||||||
+ 'declare const Long: import("@mtcute/web").Long;',
|
+ 'declare const Long: import("@mtcute/web").Long;\n'
|
||||||
|
+ 'declare const setMiddlewareOptions: (options: import("@mtcute/web").networkMiddlewares.BasicMiddlewaresOptions) => Promise<void>;',
|
||||||
filePath: 'file:///tg.d.ts',
|
filePath: 'file:///tg.d.ts',
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
|
@ -1,12 +1,10 @@
|
||||||
|
import type { BaseTelegramClientOptions, ConnectionState } from '@mtcute/web'
|
||||||
import { asNonNull } from '@fuman/utils'
|
import { asNonNull } from '@fuman/utils'
|
||||||
import { FileLocation, Long, TelegramClient } from '@mtcute/web'
|
import { FileLocation, Long, networkMiddlewares, TelegramClient } from '@mtcute/web'
|
||||||
import { nanoid } from 'nanoid'
|
import { nanoid } from 'nanoid'
|
||||||
import { swInvokeMethodInner } from '../client-inner.ts'
|
import { swInvokeMethodInner } from '../client-inner.ts'
|
||||||
import { createFileDownload } from '../download/client.ts'
|
import { createFileDownload } from '../download/client.ts'
|
||||||
|
|
||||||
type ConnectionState = import('@mtcute/web').ConnectionState
|
|
||||||
type TelegramClientOptions = import('@mtcute/web').TelegramClientOptions
|
|
||||||
|
|
||||||
const HOST_ORIGIN = import.meta.env.VITE_HOST_ORIGIN
|
const HOST_ORIGIN = import.meta.env.VITE_HOST_ORIGIN
|
||||||
|
|
||||||
declare const chobitsu: any
|
declare const chobitsu: any
|
||||||
|
@ -15,6 +13,7 @@ declare const window: typeof globalThis & {
|
||||||
__currentScript: any
|
__currentScript: any
|
||||||
__handleScriptEnd: (error: any) => void
|
__handleScriptEnd: (error: any) => void
|
||||||
tg: import('@mtcute/web').TelegramClient
|
tg: import('@mtcute/web').TelegramClient
|
||||||
|
setMiddlewareOptions: (options: networkMiddlewares.BasicMiddlewaresOptions) => Promise<void>
|
||||||
}
|
}
|
||||||
|
|
||||||
Object.defineProperty(globalThis, 'Long', { value: Long })
|
Object.defineProperty(globalThis, 'Long', { value: Long })
|
||||||
|
@ -35,14 +34,29 @@ chobitsu.setOnMessage((message: string) => {
|
||||||
|
|
||||||
let lastAccountId: string | undefined
|
let lastAccountId: string | undefined
|
||||||
let lastConnectionState: ConnectionState | undefined
|
let lastConnectionState: ConnectionState | undefined
|
||||||
|
let lastMiddlewareOptions: networkMiddlewares.BasicMiddlewaresOptions | undefined
|
||||||
let currentScriptId: string | undefined
|
let currentScriptId: string | undefined
|
||||||
let logUpdates = false
|
let logUpdates = false
|
||||||
let verboseLogs = false
|
let verboseLogs = false
|
||||||
|
|
||||||
|
Object.defineProperty(globalThis, 'setMiddlewareOptions', {
|
||||||
|
value: async (options: networkMiddlewares.BasicMiddlewaresOptions) => {
|
||||||
|
if (JSON.stringify(options) === JSON.stringify(lastMiddlewareOptions)) return
|
||||||
|
lastMiddlewareOptions = options
|
||||||
|
if (window.tg) {
|
||||||
|
await window.tg.close()
|
||||||
|
initClient(lastAccountId!, verboseLogs)
|
||||||
|
if (lastConnectionState !== 'offline') {
|
||||||
|
await window.tg.connect()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
function initClient(accountId: string, verbose: boolean) {
|
function initClient(accountId: string, verbose: boolean) {
|
||||||
lastAccountId = accountId
|
lastAccountId = accountId
|
||||||
|
|
||||||
let extraConfig: Partial<TelegramClientOptions> | undefined
|
const extraConfig: Partial<BaseTelegramClientOptions> = {}
|
||||||
|
|
||||||
const storedAccounts = localStorage.getItem('repl:accounts')
|
const storedAccounts = localStorage.getItem('repl:accounts')
|
||||||
if (storedAccounts) {
|
if (storedAccounts) {
|
||||||
|
@ -51,10 +65,14 @@ function initClient(accountId: string, verbose: boolean) {
|
||||||
if (!ourAccount) return
|
if (!ourAccount) return
|
||||||
|
|
||||||
if (ourAccount && ourAccount.testMode) {
|
if (ourAccount && ourAccount.testMode) {
|
||||||
extraConfig = {
|
extraConfig.testMode = true
|
||||||
testMode: true,
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (lastMiddlewareOptions) {
|
||||||
|
extraConfig.network = {
|
||||||
|
middlewares: networkMiddlewares.basic(lastMiddlewareOptions),
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
window.tg = new TelegramClient({
|
window.tg = new TelegramClient({
|
||||||
|
|
Loading…
Reference in a new issue