lol
This commit is contained in:
parent
cd142e4414
commit
7369ff8868
@ -2,4 +2,4 @@ export const EVENT_LISTENER = '__rpc:listener'
|
||||
export const EVENT_RESPONSE = '__rpc:response'
|
||||
export const CEF_EVENT_LISTENER = '__rpc:cef_listener'
|
||||
|
||||
export const CLIENT_ROUTER_LISTENER = '__rpc:clientRouter'
|
||||
export const CLIENT_ROUTER_EVENT = '__rpc:clientRouter'
|
||||
|
@ -1,12 +1,14 @@
|
||||
import { CLIENT_ROUTER_LISTENER } from '../events'
|
||||
import { CLIENT_ROUTER_EVENT, EVENT_LISTENER } from '../events'
|
||||
import { Wrapper } from './wrapper'
|
||||
import { Environment } from '../utils'
|
||||
|
||||
class Client extends Wrapper {
|
||||
private browser: any
|
||||
|
||||
constructor() {
|
||||
super()
|
||||
|
||||
mp.events.add(CLIENT_ROUTER_LISTENER, (data: string) => {
|
||||
mp.events.add(CLIENT_ROUTER_EVENT, (data: string) => {
|
||||
const parsedData = this._utils.prepareForExecute(data)
|
||||
const environment = this._environment
|
||||
|
||||
@ -14,21 +16,28 @@ class Client extends Wrapper {
|
||||
switch (parsedData.calledTo) {
|
||||
case Environment.SERVER:
|
||||
// route to server listener
|
||||
this.requestToServer(data)
|
||||
break
|
||||
|
||||
case Environment.CEF:
|
||||
// route to cef listener
|
||||
this.requestToBrowser(data)
|
||||
break
|
||||
}
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
public useBrowser(browser: any) {
|
||||
this.browser = browser
|
||||
}
|
||||
|
||||
private async createCallbackListener(uuid: string) {
|
||||
const eventName = this._utils.generateResponseEventName(uuid)
|
||||
|
||||
const handler = async (data: string) => {
|
||||
mp.events.remove(eventName)
|
||||
|
||||
//TODO: transfer to CEF/Server
|
||||
}
|
||||
|
||||
mp.events.add(eventName, handler)
|
||||
@ -38,16 +47,18 @@ class Client extends Wrapper {
|
||||
|
||||
private async requestToServer(data: string) {
|
||||
const { uuid } = this._utils.prepareForExecute(data)
|
||||
const callbackEventName = await this.createCallbackListener(uuid)
|
||||
await this.createCallbackListener(uuid)
|
||||
|
||||
mp.events.callRemote(callbackEventName, data)
|
||||
mp.events.callRemote(EVENT_LISTENER, data)
|
||||
}
|
||||
|
||||
private async requestToBrowser(data: string) {
|
||||
const { uuid } = this._utils.prepareForExecute(data)
|
||||
const callbackEventName = await this.createCallbackListener(uuid)
|
||||
await this.createCallbackListener(uuid)
|
||||
|
||||
mp.browsers.at(0).call()
|
||||
if (!this.browser) return //TODO: Error browser not initialized
|
||||
|
||||
this.browser.call(EVENT_LISTENER, data)
|
||||
}
|
||||
|
||||
// private sendResponseToServer(data: RPCState) {
|
||||
|
Loading…
Reference in New Issue
Block a user