Rpc integration + type fixes #3
@ -2,4 +2,4 @@ export const EVENT_LISTENER = '__rpc:listener'
|
|||||||
export const EVENT_RESPONSE = '__rpc:response'
|
export const EVENT_RESPONSE = '__rpc:response'
|
||||||
export const CEF_EVENT_LISTENER = '__rpc:cef_listener'
|
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 { Wrapper } from './wrapper'
|
||||||
import { Environment } from '../utils'
|
import { Environment } from '../utils'
|
||||||
|
|
||||||
class Client extends Wrapper {
|
class Client extends Wrapper {
|
||||||
|
private browser: any
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
super()
|
super()
|
||||||
|
|
||||||
mp.events.add(CLIENT_ROUTER_LISTENER, (data: string) => {
|
mp.events.add(CLIENT_ROUTER_EVENT, (data: string) => {
|
||||||
const parsedData = this._utils.prepareForExecute(data)
|
const parsedData = this._utils.prepareForExecute(data)
|
||||||
const environment = this._environment
|
const environment = this._environment
|
||||||
|
|
||||||
@ -14,21 +16,28 @@ class Client extends Wrapper {
|
|||||||
switch (parsedData.calledTo) {
|
switch (parsedData.calledTo) {
|
||||||
case Environment.SERVER:
|
case Environment.SERVER:
|
||||||
// route to server listener
|
// route to server listener
|
||||||
|
this.requestToServer(data)
|
||||||
break
|
break
|
||||||
|
|
||||||
case Environment.CEF:
|
case Environment.CEF:
|
||||||
// route to cef listener
|
this.requestToBrowser(data)
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public useBrowser(browser: any) {
|
||||||
|
this.browser = browser
|
||||||
|
}
|
||||||
|
|
||||||
private async createCallbackListener(uuid: string) {
|
private async createCallbackListener(uuid: string) {
|
||||||
const eventName = this._utils.generateResponseEventName(uuid)
|
const eventName = this._utils.generateResponseEventName(uuid)
|
||||||
|
|
||||||
const handler = async (data: string) => {
|
const handler = async (data: string) => {
|
||||||
mp.events.remove(eventName)
|
mp.events.remove(eventName)
|
||||||
|
|
||||||
|
//TODO: transfer to CEF/Server
|
||||||
}
|
}
|
||||||
|
|
||||||
mp.events.add(eventName, handler)
|
mp.events.add(eventName, handler)
|
||||||
@ -38,16 +47,18 @@ class Client extends Wrapper {
|
|||||||
|
|
||||||
private async requestToServer(data: string) {
|
private async requestToServer(data: string) {
|
||||||
const { uuid } = this._utils.prepareForExecute(data)
|
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) {
|
private async requestToBrowser(data: string) {
|
||||||
const { uuid } = this._utils.prepareForExecute(data)
|
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) {
|
// private sendResponseToServer(data: RPCState) {
|
||||||
|
Loading…
Reference in New Issue
Block a user