2018-04-21 02:59:30 -03:00
|
|
|
|
/*****************************************************************************\
|
|
|
|
|
| ( )_ _ |
|
|
|
|
|
| _ _ _ __ _ _ __ ___ ___ _ _ | ,_)(_) ___ ___ _ |
|
2020-07-01 15:00:40 -03:00
|
|
|
|
| ( '_`\ ( '__)/'_` ) /'_ `\/' _ ` _ `\ /'_` )| | | |/',__)/' v `\ /'_`\ |
|
2019-03-09 16:59:31 -03:00
|
|
|
|
| | (_) )| | ( (_| |( (_) || ( ) ( ) |( (_| || |_ | |\__, \| (˅) |( (_) ) |
|
2018-04-21 02:59:30 -03:00
|
|
|
|
| | ,__/'(_) `\__,_)`\__ |(_) (_) (_)`\__,_)`\__)(_)(____/(_) (_)`\___/' |
|
|
|
|
|
| | | ( )_) | |
|
|
|
|
|
| (_) \___/' |
|
|
|
|
|
| |
|
|
|
|
|
| General Bots Copyright (c) Pragmatismo.io. All rights reserved. |
|
|
|
|
|
| Licensed under the AGPL-3.0. |
|
2018-11-11 19:09:18 -02:00
|
|
|
|
| |
|
2018-04-21 02:59:30 -03:00
|
|
|
|
| According to our dual licensing model, this program can be used either |
|
|
|
|
|
| under the terms of the GNU Affero General Public License, version 3, |
|
|
|
|
|
| or under a proprietary license. |
|
|
|
|
|
| |
|
|
|
|
|
| The texts of the GNU Affero General Public License with an additional |
|
|
|
|
|
| permission and of our proprietary license can be found at and |
|
|
|
|
|
| in the LICENSE file you have received along with this program. |
|
|
|
|
|
| |
|
|
|
|
|
| This program is distributed in the hope that it will be useful, |
|
2018-09-11 19:40:53 -03:00
|
|
|
|
| but WITHOUT ANY WARRANTY, without even the implied warranty of |
|
2018-04-21 02:59:30 -03:00
|
|
|
|
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
|
|
|
|
| GNU Affero General Public License for more details. |
|
|
|
|
|
| |
|
|
|
|
|
| "General Bots" is a registered trademark of Pragmatismo.io. |
|
|
|
|
|
| The licensing of the program under the AGPLv3 does not imply a |
|
|
|
|
|
| trademark license. Therefore any rights, title and interest in |
|
|
|
|
|
| our trademarks remain entirely with us. |
|
|
|
|
|
| |
|
|
|
|
|
\*****************************************************************************/
|
|
|
|
|
|
2018-11-26 14:09:09 -02:00
|
|
|
|
'use strict';
|
|
|
|
|
|
2020-08-29 15:02:19 -03:00
|
|
|
|
import { GBLog, GBMinInstance, GBService, IGBCoreService, GBDialogStep } from 'botlib';
|
2022-11-18 22:39:14 -03:00
|
|
|
|
import * as Fs from 'fs';
|
|
|
|
|
import { GBDeployer } from '../../core.gbapp/services/GBDeployer.js';
|
|
|
|
|
import { TSCompiler } from './TSCompiler.js';
|
2020-06-14 21:40:41 -03:00
|
|
|
|
import { CollectionUtil } from 'pragmatismo-io-framework';
|
2022-11-18 22:39:14 -03:00
|
|
|
|
import { ScheduleServices } from './ScheduleServices.js';
|
|
|
|
|
import { GBConfigService } from '../../core.gbapp/services/GBConfigService.js';
|
|
|
|
|
import urlJoin from 'url-join';
|
|
|
|
|
import { NodeVM, VMScript } from 'vm2';
|
|
|
|
|
import { createVm2Pool } from './vm2-process/index.js';
|
2022-11-19 23:34:58 -03:00
|
|
|
|
import * as vb2ts from './vbscript-to-typescript.js';
|
2022-11-18 22:39:14 -03:00
|
|
|
|
import textract from 'textract';
|
|
|
|
|
import walkPromise from 'walk-promise';
|
|
|
|
|
import child_process from 'child_process';
|
|
|
|
|
import Path from 'path';
|
|
|
|
|
import indent from 'indent.js';
|
2018-11-11 19:09:18 -02:00
|
|
|
|
/**
|
2022-11-19 23:34:58 -03:00
|
|
|
|
* @fileoverview Decision was to priorize security(isolation) and debugging,
|
2022-11-10 10:39:05 -03:00
|
|
|
|
* over a beautiful BASIC transpiler (to be done).
|
2018-11-11 19:09:18 -02:00
|
|
|
|
*/
|
|
|
|
|
|
2019-03-09 16:59:31 -03:00
|
|
|
|
/**
|
|
|
|
|
* Basic services for BASIC manipulation.
|
|
|
|
|
*/
|
2019-03-08 06:37:13 -03:00
|
|
|
|
export class GBVMService extends GBService {
|
2022-11-19 23:34:58 -03:00
|
|
|
|
public async loadDialogPackage (folder: string, min: GBMinInstance, core: IGBCoreService, deployer: GBDeployer) {
|
2019-02-23 13:17:21 -03:00
|
|
|
|
const files = await walkPromise(folder);
|
|
|
|
|
|
2020-06-14 21:40:41 -03:00
|
|
|
|
await CollectionUtil.asyncForEach(files, async file => {
|
|
|
|
|
if (!file) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let filename: string = file.name;
|
|
|
|
|
|
|
|
|
|
if (filename.endsWith('.docx')) {
|
|
|
|
|
const wordFile = filename;
|
|
|
|
|
const vbsFile = filename.substr(0, filename.indexOf('docx')) + 'vbs';
|
|
|
|
|
const fullVbsFile = urlJoin(folder, vbsFile);
|
2022-11-18 22:39:14 -03:00
|
|
|
|
const docxStat = Fs.statSync(urlJoin(folder, wordFile));
|
2022-08-05 00:10:23 -03:00
|
|
|
|
const interval = 3000; // If compiled is older 30 seconds, then recompile.
|
2020-06-14 21:40:41 -03:00
|
|
|
|
let writeVBS = true;
|
2022-11-18 22:39:14 -03:00
|
|
|
|
if (Fs.existsSync(fullVbsFile)) {
|
|
|
|
|
const vbsStat = Fs.statSync(fullVbsFile);
|
2022-10-12 15:08:53 -03:00
|
|
|
|
if (docxStat['mtimeMs'] < vbsStat['mtimeMs'] + interval) {
|
2020-06-14 21:40:41 -03:00
|
|
|
|
writeVBS = false;
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-08-09 17:55:55 -03:00
|
|
|
|
filename = vbsFile;
|
|
|
|
|
let mainName = GBVMService.getMethodNameFromVBSFilename(filename);
|
|
|
|
|
min.scriptMap[filename] = mainName;
|
|
|
|
|
|
2020-06-14 21:40:41 -03:00
|
|
|
|
if (writeVBS) {
|
|
|
|
|
let text = await this.getTextFromWord(folder, wordFile);
|
2020-05-14 12:46:57 -03:00
|
|
|
|
|
2021-08-09 17:55:55 -03:00
|
|
|
|
const schedule = GBVMService.getSetScheduleKeywordArgs(text);
|
|
|
|
|
const s = new ScheduleServices();
|
|
|
|
|
if (schedule) {
|
|
|
|
|
await s.createOrUpdateSchedule(min, schedule, mainName);
|
2022-11-19 23:34:58 -03:00
|
|
|
|
} else {
|
2021-08-09 17:55:55 -03:00
|
|
|
|
await s.deleteScheduleIfAny(min, mainName);
|
2021-08-16 17:38:05 -03:00
|
|
|
|
}
|
2022-11-11 10:01:18 -03:00
|
|
|
|
text = text.replace(/^\s*SET SCHEDULE (.*)/gim, '');
|
2022-11-18 22:39:14 -03:00
|
|
|
|
Fs.writeFileSync(urlJoin(folder, vbsFile), text);
|
2021-08-09 17:55:55 -03:00
|
|
|
|
}
|
2020-06-04 13:44:02 -03:00
|
|
|
|
|
2022-11-02 16:03:25 -03:00
|
|
|
|
// Process node_modules install.
|
|
|
|
|
|
|
|
|
|
const node_modules = urlJoin(folder, 'node_modules');
|
2022-11-18 22:39:14 -03:00
|
|
|
|
if (!Fs.existsSync(node_modules)) {
|
2022-11-02 16:03:25 -03:00
|
|
|
|
const packageJson = `
|
|
|
|
|
{
|
|
|
|
|
"name": "${min.botId}.gbdialog",
|
|
|
|
|
"version": "1.0.0",
|
|
|
|
|
"description": "${min.botId} transpiled .gbdialog",
|
|
|
|
|
"author": "${min.botId} owner.",
|
|
|
|
|
"license": "ISC",
|
|
|
|
|
"dependencies": {
|
|
|
|
|
"encoding": "0.1.13",
|
|
|
|
|
"isomorphic-fetch": "3.0.0",
|
|
|
|
|
"punycode": "2.1.1",
|
|
|
|
|
"typescript-rest-rpc": "1.0.10",
|
|
|
|
|
"vm2": "3.9.11"
|
|
|
|
|
}
|
|
|
|
|
}`;
|
2022-11-18 22:39:14 -03:00
|
|
|
|
Fs.writeFileSync(urlJoin(folder, 'package.json'), packageJson);
|
2022-11-02 16:03:25 -03:00
|
|
|
|
|
|
|
|
|
GBLog.info(`BASIC: Installing .gbdialog node_modules for ${min.botId}...`);
|
|
|
|
|
const npmPath = urlJoin(process.env.PWD, 'node_modules', '.bin', 'npm');
|
|
|
|
|
child_process.execSync(`${npmPath} install`, { cwd: folder });
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Hot swap for .vbs files.
|
|
|
|
|
|
2020-06-14 21:40:41 -03:00
|
|
|
|
const fullFilename = urlJoin(folder, filename);
|
2022-11-02 16:03:25 -03:00
|
|
|
|
if (process.env.GBDIALOG_HOTSWAP) {
|
2022-11-18 22:39:14 -03:00
|
|
|
|
Fs.watchFile(fullFilename, async () => {
|
2022-11-02 16:03:25 -03:00
|
|
|
|
await this.translateBASIC(fullFilename, min, deployer, mainName);
|
|
|
|
|
});
|
|
|
|
|
}
|
2020-06-14 21:40:41 -03:00
|
|
|
|
|
2022-11-18 22:39:14 -03:00
|
|
|
|
const compiledAt = Fs.statSync(fullFilename);
|
2020-06-14 21:40:41 -03:00
|
|
|
|
const jsfile = urlJoin(folder, `${filename}.js`);
|
|
|
|
|
|
2022-11-18 22:39:14 -03:00
|
|
|
|
if (Fs.existsSync(jsfile)) {
|
|
|
|
|
const jsStat = Fs.statSync(jsfile);
|
2020-06-14 21:40:41 -03:00
|
|
|
|
const interval = 30000; // If compiled is older 30 seconds, then recompile.
|
2022-10-12 15:08:53 -03:00
|
|
|
|
if (compiledAt.isFile() && compiledAt['mtimeMs'] > jsStat['mtimeMs'] + interval) {
|
2022-11-02 16:03:25 -03:00
|
|
|
|
await this.translateBASIC(fullFilename, min, deployer, mainName);
|
2020-08-29 15:02:19 -03:00
|
|
|
|
} else {
|
2022-11-18 22:39:14 -03:00
|
|
|
|
const parsedCode: string = Fs.readFileSync(jsfile, 'utf8');
|
2021-08-09 17:55:55 -03:00
|
|
|
|
|
2022-11-02 16:03:25 -03:00
|
|
|
|
min.sandBoxMap[mainName.toLowerCase().trim()] = parsedCode;
|
2020-06-04 13:44:02 -03:00
|
|
|
|
}
|
2020-08-29 15:02:19 -03:00
|
|
|
|
} else {
|
2022-11-02 16:03:25 -03:00
|
|
|
|
await this.translateBASIC(fullFilename, min, deployer, mainName);
|
2020-06-14 21:40:41 -03:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
2019-02-23 13:17:21 -03:00
|
|
|
|
}
|
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
public async translateBASIC (filename: any, min: GBMinInstance, deployer: GBDeployer, mainName: string) {
|
2022-11-02 19:40:59 -03:00
|
|
|
|
// Converts General Bots BASIC into regular VBS
|
|
|
|
|
|
2022-11-18 22:39:14 -03:00
|
|
|
|
let basicCode: string = Fs.readFileSync(filename, 'utf8');
|
2022-11-02 19:40:59 -03:00
|
|
|
|
|
|
|
|
|
// Processes END keyword, removing extracode, useful
|
2022-11-19 23:34:58 -03:00
|
|
|
|
// for development in .gbdialog.
|
2022-11-02 19:40:59 -03:00
|
|
|
|
|
2022-11-06 20:19:05 -03:00
|
|
|
|
if (process.env.GBDIALOG_NOEND === 'true') {
|
2022-11-11 10:01:18 -03:00
|
|
|
|
basicCode = basicCode.replace(/^\s*END(\W|\n)/gim, '');
|
2022-11-19 23:34:58 -03:00
|
|
|
|
} else {
|
2022-11-11 10:01:18 -03:00
|
|
|
|
let end = /^\s*END(\W|\n)/gi.exec(basicCode);
|
2022-11-06 20:19:05 -03:00
|
|
|
|
if (end) {
|
|
|
|
|
basicCode = basicCode.substring(0, end.index);
|
|
|
|
|
}
|
|
|
|
|
}
|
2022-11-02 19:40:59 -03:00
|
|
|
|
|
|
|
|
|
// Removes comments.
|
|
|
|
|
|
2022-11-10 10:39:05 -03:00
|
|
|
|
basicCode = basicCode.replace(/^\s*REM.*/gim, '');
|
|
|
|
|
basicCode = basicCode.replace(/^\s*\'.*/gim, '');
|
2022-11-02 19:40:59 -03:00
|
|
|
|
|
|
|
|
|
// Process INCLUDE keyword to include another
|
|
|
|
|
// dialog inside the dialog.
|
|
|
|
|
|
|
|
|
|
let include = null;
|
|
|
|
|
do {
|
2022-11-19 23:34:58 -03:00
|
|
|
|
include = /^include\b(.*)$/gim.exec(basicCode);
|
2022-11-02 19:40:59 -03:00
|
|
|
|
|
|
|
|
|
if (include) {
|
|
|
|
|
let includeName = include[1].trim();
|
|
|
|
|
includeName = Path.join(Path.dirname(filename), includeName);
|
2022-11-19 23:34:58 -03:00
|
|
|
|
includeName = includeName.substr(0, includeName.lastIndexOf('.')) + '.vbs';
|
2022-11-02 19:40:59 -03:00
|
|
|
|
|
|
|
|
|
// To use include, two /publish will be necessary (for now)
|
|
|
|
|
// because of alphabet order may raise not found errors.
|
|
|
|
|
|
2022-11-18 22:39:14 -03:00
|
|
|
|
let includeCode: string = Fs.readFileSync(includeName, 'utf8');
|
2022-11-19 23:34:58 -03:00
|
|
|
|
basicCode = basicCode.replace(/^include\b.*$/gim, includeCode);
|
2022-11-02 19:40:59 -03:00
|
|
|
|
}
|
|
|
|
|
} while (include);
|
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
const { code, jsonMap } = await this.convertGBASICToVBS(min, basicCode);
|
2022-11-02 19:40:59 -03:00
|
|
|
|
const vbsFile = `${filename}.compiled`;
|
2022-11-12 17:17:14 -03:00
|
|
|
|
const mapFile = `${filename}.map`;
|
|
|
|
|
|
2022-11-18 22:39:14 -03:00
|
|
|
|
Fs.writeFileSync(vbsFile, code);
|
|
|
|
|
Fs.writeFileSync(mapFile, JSON.stringify(jsonMap));
|
2022-11-02 19:40:59 -03:00
|
|
|
|
|
|
|
|
|
// Converts VBS into TS.
|
|
|
|
|
|
|
|
|
|
vb2ts.convertFile(vbsFile);
|
|
|
|
|
|
|
|
|
|
// Convert TS into JS.
|
|
|
|
|
|
|
|
|
|
const tsfile: string = `${filename}.ts`;
|
2022-11-18 22:39:14 -03:00
|
|
|
|
let tsCode: string = Fs.readFileSync(tsfile, 'utf8');
|
|
|
|
|
Fs.writeFileSync(tsfile, tsCode);
|
2022-11-02 19:40:59 -03:00
|
|
|
|
const tsc = new TSCompiler();
|
|
|
|
|
tsc.compile([tsfile]);
|
|
|
|
|
|
|
|
|
|
// Run JS into the GB context.
|
|
|
|
|
|
|
|
|
|
const jsfile = `${tsfile}.js`.replace('.ts', '');
|
|
|
|
|
|
2022-11-18 22:39:14 -03:00
|
|
|
|
if (Fs.existsSync(jsfile)) {
|
|
|
|
|
let code: string = Fs.readFileSync(jsfile, 'utf8');
|
2022-11-02 19:40:59 -03:00
|
|
|
|
|
2022-11-11 21:35:05 -03:00
|
|
|
|
code.replace(/^.*exports.*$/gm, '');
|
2022-11-02 19:40:59 -03:00
|
|
|
|
|
|
|
|
|
code = `
|
|
|
|
|
return (async () => {
|
|
|
|
|
require('isomorphic-fetch');
|
2023-01-05 10:47:40 -03:00
|
|
|
|
const rest = require('typescript-rest-rpc/lib/client');
|
2022-11-02 19:40:59 -03:00
|
|
|
|
|
|
|
|
|
// Interprocess communication from local HTTP to the BotServer.
|
|
|
|
|
|
|
|
|
|
const dk = rest.createClient('http://localhost:1111/api/v2/${min.botId}/dialog');
|
|
|
|
|
const sys = rest.createClient('http://localhost:1111/api/v2/${min.botId}/system');
|
2022-11-03 11:06:26 -03:00
|
|
|
|
const wa = rest.createClient('http://localhost:1111/api/v2/${min.botId}/webautomation');
|
2022-11-02 19:40:59 -03:00
|
|
|
|
|
|
|
|
|
// Local variables.
|
|
|
|
|
|
|
|
|
|
const gb = await dk.getSingleton();
|
|
|
|
|
const id = gb.id;
|
|
|
|
|
const username = gb.username;
|
|
|
|
|
const mobile = gb.mobile;
|
|
|
|
|
const from = gb.from;
|
|
|
|
|
const ENTER = gb.ENTER;
|
|
|
|
|
const headers = gb.headers;
|
|
|
|
|
const data = gb.data;
|
|
|
|
|
const list = gb.list;
|
|
|
|
|
const httpUsername = gb.httpUsername;
|
|
|
|
|
const httpPs = gb.httpPs;
|
2022-11-03 11:06:26 -03:00
|
|
|
|
let page = null;
|
|
|
|
|
|
2022-11-02 19:40:59 -03:00
|
|
|
|
|
|
|
|
|
// Local functions.
|
|
|
|
|
|
|
|
|
|
const ubound = (array) => {return array.length};
|
|
|
|
|
const isarray = (array) => {return Array.isArray(array) };
|
|
|
|
|
|
|
|
|
|
// Remote functions.
|
|
|
|
|
|
2022-11-03 11:06:26 -03:00
|
|
|
|
const weekday = (v) => { return (async () => { return await dk.getWeekFromDate({v}) })(); };
|
|
|
|
|
const hour = (v) => { return (async () => { return await dk.getHourFromDate({v}) })(); };
|
|
|
|
|
const base64 = (v) => { return (async () => { return await dk.getCoded({v}) })(); };
|
|
|
|
|
const tolist = (v) => { return (async () => { return await dk.getToLst({v}) })(); };
|
|
|
|
|
const now = (v) => { return (async () => { return await dk.getNow({v}) })(); };
|
|
|
|
|
const today = (v) => { return (async () => { return await dk.getToday({v}) })(); };
|
2022-11-02 19:40:59 -03:00
|
|
|
|
|
|
|
|
|
${code}
|
|
|
|
|
|
|
|
|
|
})();
|
|
|
|
|
|
|
|
|
|
`;
|
2022-11-19 23:34:58 -03:00
|
|
|
|
code = indent.js(code, { tabString: '\t' });
|
2022-11-18 22:39:14 -03:00
|
|
|
|
Fs.writeFileSync(jsfile, code);
|
2022-11-12 17:17:14 -03:00
|
|
|
|
min.sandBoxMap[mainName.toLowerCase().trim()] = code;
|
|
|
|
|
GBLog.info(`[GBVMService] Finished loading of ${filename}, JavaScript from Word: \n ${code}`);
|
2022-11-02 19:40:59 -03:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
public static getMethodNameFromVBSFilename (filename: string) {
|
2023-01-04 16:26:18 -03:00
|
|
|
|
let mainName = filename.replace(/\s*|\-/gim, '').split('.')[0];
|
2020-11-06 17:06:22 -03:00
|
|
|
|
return mainName.toLowerCase();
|
|
|
|
|
}
|
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
public static getSetScheduleKeywordArgs (code: string) {
|
|
|
|
|
if (!code) return null;
|
2022-11-11 10:01:18 -03:00
|
|
|
|
const keyword = /^\s*SET SCHEDULE (.*)/gim;
|
2021-08-09 17:55:55 -03:00
|
|
|
|
const result = keyword.exec(code);
|
|
|
|
|
return result ? result[1] : null;
|
|
|
|
|
}
|
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
private async getTextFromWord (folder: string, filename: string) {
|
2020-05-15 14:07:30 -03:00
|
|
|
|
return new Promise<string>(async (resolve, reject) => {
|
2020-08-29 15:02:19 -03:00
|
|
|
|
textract.fromFileWithPath(urlJoin(folder, filename), { preserveLineBreaks: true }, (error, text) => {
|
|
|
|
|
if (error) {
|
|
|
|
|
reject(error);
|
|
|
|
|
} else {
|
2022-12-14 08:23:39 -03:00
|
|
|
|
text = text.replace('¨', '"');
|
2020-08-29 15:02:19 -03:00
|
|
|
|
text = text.replace('“', '"');
|
|
|
|
|
text = text.replace('”', '"');
|
|
|
|
|
text = text.replace('‘', "'");
|
|
|
|
|
text = text.replace('’', "'");
|
|
|
|
|
|
|
|
|
|
resolve(text);
|
|
|
|
|
}
|
|
|
|
|
});
|
2020-05-15 14:07:30 -03:00
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2022-11-11 21:35:05 -03:00
|
|
|
|
private getParams = (text, names) => {
|
|
|
|
|
let ret = {};
|
2022-11-19 23:34:58 -03:00
|
|
|
|
const splitParamsButIgnoreCommasInDoublequotes = str => {
|
|
|
|
|
return str.split(',').reduce(
|
|
|
|
|
(accum, curr) => {
|
|
|
|
|
if (accum.isConcatting) {
|
|
|
|
|
accum.soFar[accum.soFar.length - 1] += ',' + curr;
|
|
|
|
|
} else {
|
|
|
|
|
accum.soFar.push(curr);
|
|
|
|
|
}
|
|
|
|
|
if (curr.split('"').length % 2 == 0) {
|
|
|
|
|
accum.isConcatting = !accum.isConcatting;
|
|
|
|
|
}
|
|
|
|
|
return accum;
|
|
|
|
|
},
|
|
|
|
|
{ soFar: [], isConcatting: false }
|
|
|
|
|
).soFar;
|
|
|
|
|
};
|
2022-11-11 21:35:05 -03:00
|
|
|
|
|
|
|
|
|
const items = splitParamsButIgnoreCommasInDoublequotes(text);
|
|
|
|
|
|
|
|
|
|
let i = 0;
|
|
|
|
|
let json = '{';
|
|
|
|
|
names.forEach(name => {
|
|
|
|
|
let value = items[i];
|
|
|
|
|
i++;
|
|
|
|
|
json = `${json} "${name}": ${value} ${names.length == i ? '' : ','}`;
|
|
|
|
|
});
|
2022-11-19 23:34:58 -03:00
|
|
|
|
json = `${json}}`;
|
2022-11-11 21:35:05 -03:00
|
|
|
|
|
|
|
|
|
return json;
|
|
|
|
|
};
|
|
|
|
|
|
2019-02-23 13:17:21 -03:00
|
|
|
|
/**
|
|
|
|
|
* Converts General Bots BASIC
|
|
|
|
|
*
|
|
|
|
|
*
|
|
|
|
|
* @param code General Bots BASIC
|
|
|
|
|
*/
|
2022-11-19 23:34:58 -03:00
|
|
|
|
public async convertGBASICToVBS (min: GBMinInstance, code: string) {
|
2022-11-02 16:03:25 -03:00
|
|
|
|
// Start and End of VB2TS tags of processing.
|
2020-11-22 11:22:55 -03:00
|
|
|
|
|
2020-05-11 10:41:41 -03:00
|
|
|
|
code = `<%\n
|
2022-11-02 16:03:25 -03:00
|
|
|
|
|
2022-05-03 17:05:57 -03:00
|
|
|
|
${process.env.ENABLE_AUTH ? `hear gbLogin as login` : ``}
|
2021-08-30 16:30:10 -03:00
|
|
|
|
|
2020-05-11 10:41:41 -03:00
|
|
|
|
${code}
|
2022-10-09 20:46:17 -03:00
|
|
|
|
|
2020-05-11 10:41:41 -03:00
|
|
|
|
`;
|
2019-02-23 13:17:21 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
var allLines = code.split('\n');
|
2022-11-12 17:17:14 -03:00
|
|
|
|
const keywords = this.getKeywords();
|
2022-11-12 23:26:47 -03:00
|
|
|
|
const offset = 34;
|
2022-11-12 17:17:14 -03:00
|
|
|
|
const jsonMap = {};
|
2022-11-04 14:28:02 -03:00
|
|
|
|
|
2022-11-11 21:35:05 -03:00
|
|
|
|
for (var i = 0; i < allLines.length; i++) {
|
2022-11-12 17:17:14 -03:00
|
|
|
|
for (var j = 0; j < keywords.length; j++) {
|
|
|
|
|
allLines[i] = allLines[i].replace(keywords[j][0], keywords[j][1]);
|
2022-11-04 14:28:02 -03:00
|
|
|
|
|
2022-11-12 17:17:14 -03:00
|
|
|
|
// Add additional lines returned from replacement.
|
2022-11-04 14:28:02 -03:00
|
|
|
|
|
2022-11-12 17:17:14 -03:00
|
|
|
|
let add = allLines[i].split(/\r\n|\r|\n/).length;
|
2022-11-19 23:34:58 -03:00
|
|
|
|
jsonMap[i] = offset + i + (add ? add : 0);
|
2022-11-12 17:17:14 -03:00
|
|
|
|
}
|
|
|
|
|
}
|
2022-11-11 21:35:05 -03:00
|
|
|
|
|
2022-11-12 17:17:14 -03:00
|
|
|
|
code = `${allLines.join('\n')}\n%>`;
|
2022-11-19 23:34:58 -03:00
|
|
|
|
return { code, jsonMap };
|
2022-11-11 21:35:05 -03:00
|
|
|
|
}
|
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
private getKeywords () {
|
2019-02-23 13:17:21 -03:00
|
|
|
|
// Keywords from General Bots BASIC.
|
2022-06-01 19:45:43 -03:00
|
|
|
|
|
2022-11-11 21:35:05 -03:00
|
|
|
|
let keywords = [];
|
|
|
|
|
let i = 0;
|
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\w+)\s*\=\s*SELECT\s*(.*)/gim,
|
|
|
|
|
($0, $1, $2) => {
|
2023-01-04 16:26:18 -03:00
|
|
|
|
let tableName = /\s*FROM\s*(\w+)/.exec($2)[1];
|
2022-11-19 23:34:58 -03:00
|
|
|
|
let sql = `SELECT ${$2}`.replace(tableName, '?');
|
|
|
|
|
return `${$1} = await sys.executeSQL({data:${$1}, sql:"${sql}", tableName:"${tableName}"})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-06-04 17:02:34 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*open\s*(.*)/gim,
|
|
|
|
|
($0, $1, $2) => {
|
|
|
|
|
if (!$1.startsWith('"') && !$1.startsWith("'")) {
|
|
|
|
|
$1 = `"${$1}"`;
|
|
|
|
|
}
|
|
|
|
|
const params = this.getParams($1, ['url', 'username', 'password']);
|
2022-11-06 20:19:05 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
return `page = await wa.getPage(${params})\n`;
|
2022-11-06 20:19:05 -03:00
|
|
|
|
}
|
2022-11-19 23:34:58 -03:00
|
|
|
|
];
|
2022-11-02 16:03:25 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(set hear on)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `hrOn = ${$3}\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2019-02-23 13:17:21 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*hear (\w+) as login/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `${$1} = await dk.getHear({kind:"login"})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-11-02 16:03:25 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*hear (\w+) as email/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `${$1} = await dk.getHear({kind:"email"})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-12-07 22:25:43 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*hear (\w+) as integer/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `${$1} = await dk.getHear({kind:"integer"})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-12-07 22:25:43 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*hear (\w+) as file/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `${$1} = await dk.getHear({kind:"file"})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-06-03 23:52:28 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*hear (\w+) as boolean/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `${$1} = await dk.getHear({kind:"boolean"})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-12-07 23:24:00 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*hear (\w+) as name/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `${$1} = await dk.getHear({kind:"name"})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-12-07 22:25:43 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*hear (\w+) as date/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `${$1} = await dk.getHear({kind:"date"})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-12-07 22:25:43 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*hear (\w+) as hour/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `${$1} = await dk.getHear({kind:"hour"})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-12-07 22:25:43 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*hear (\w+) as phone/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `${$1} = await dk.getHear({kind:"phone"})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-12-07 22:25:43 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*hear (\w+) as money/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `${$1} = await dk.getHear({kind:"money")}`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-12-07 22:25:43 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*hear (\w+) as language/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `${$1} = await dk.getHear({kind:"language")}`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-12-22 21:48:41 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*hear (\w+) as zipcode/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `${$1} = await dk.getHear({kind:"zipcode")}`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-12-07 23:08:52 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*hear (\w+) as (.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2) => {
|
|
|
|
|
return `${$1} = await dk.getHear({kind:"menu", args: [${$2}])}`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-05-14 12:46:57 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(hear)\s*(\w+)/gim,
|
|
|
|
|
($0, $1, $2) => {
|
|
|
|
|
return `${$2} = await dk.getHear({})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-07-07 10:15:39 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\w+)\s*\=\s*find contact\s*(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `${$1} = await dk.fndContact({${$2})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-12-20 20:27:02 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\w+)\s*=\s*find\s*(.*)\s*or talk\s*(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `${$1} = await sys.find({args:[${$2}])\n
|
2021-08-16 17:38:05 -03:00
|
|
|
|
if (!${$1}) {
|
2022-11-03 11:06:26 -03:00
|
|
|
|
await dk.talk ({${$3}})\n;
|
2021-08-16 17:38:05 -03:00
|
|
|
|
return -1;
|
2021-05-18 14:22:10 -03:00
|
|
|
|
}
|
|
|
|
|
`;
|
2022-11-19 23:34:58 -03:00
|
|
|
|
}
|
|
|
|
|
];
|
2021-05-18 14:22:10 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*CALL\s*(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `await ${$1}\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-08-01 18:36:45 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\w+)\s*\=\s*find\s*(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `
|
2022-11-11 21:35:05 -03:00
|
|
|
|
${$1} = await sys.find({args: [${$2}]})\n`;
|
2022-11-19 23:34:58 -03:00
|
|
|
|
}
|
|
|
|
|
];
|
2019-02-23 13:17:21 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*(\w+)\s*\=\s*create deal(\s*)(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams($3, ['dealName', 'contact', 'company', 'amount']);
|
2022-11-05 17:59:41 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
return `${$1} = await dk.createDeal(${params})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-12-20 18:27:10 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\w+)\s*\=\s*active tasks/gim,
|
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `${$1} = await dk.getActiveTasks({})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-05-03 17:05:57 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\w+)\s*\=\s*append\s*(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `${$1} = await sys.append({args:[${$2}]})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-08-03 16:24:59 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\w+)\s*\=\s*sort\s*(\w+)\s*by(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `${$1} = await sys.sortBy({array: ${$2}, memberName: "${$3}"})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-08-03 16:24:59 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*see\s*text\s*of\s*(\w+)\s*as\s*(\w+)\s*/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `${$2} = await sys.seeText({url: ${$1})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-11-16 14:53:52 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*see\s*caption\s*of\s*(\w+)\s*as(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `${$2} = await sys.seeCaption({url: ${$1})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-11-16 14:53:52 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(wait)\s*(\d+)/gim,
|
|
|
|
|
($0, $1, $2) => {
|
|
|
|
|
return `await sys.wait({seconds:${$2}})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2019-02-23 13:17:21 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(get stock for )(.*)/gim,
|
|
|
|
|
($0, $1, $2) => {
|
|
|
|
|
return `stock = await sys.getStock({symbol: ${$2})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2019-02-23 13:17:21 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*(\w+)\s*\=\s*get\s*(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const count = ($2.match(/\,/g) || []).length;
|
|
|
|
|
const values = $2.split(',');
|
2022-05-29 15:16:38 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
// Handles GET "selector".
|
2022-05-29 15:16:38 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
if (count == 1) {
|
|
|
|
|
return `${$1} = await wa.getBySelector({handle:page, selector: ${values[0]}})`;
|
|
|
|
|
}
|
2022-06-01 19:45:43 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
// Handles GET "frameSelector", "selector"
|
|
|
|
|
else if (count == 2) {
|
|
|
|
|
return `${$1} = await wa.getByFrame({handle: page, ${values[0]}, frameOrSelector: ${values[1]}, selector: ${
|
|
|
|
|
values[2]
|
|
|
|
|
}})`;
|
|
|
|
|
}
|
2022-05-29 15:16:38 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
// Handles the GET http version.
|
|
|
|
|
else {
|
|
|
|
|
return `${$1} = await sys.get ({file: ${$2}, addressOrHeaders: headers, httpUsername, httpPs})`;
|
|
|
|
|
}
|
2022-08-26 09:53:00 -03:00
|
|
|
|
}
|
2022-11-19 23:34:58 -03:00
|
|
|
|
];
|
2022-05-29 15:16:38 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/\= NEW OBJECT/gi,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return ` = {}`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-06-01 19:45:43 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/\= NEW ARRAY/gi,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return ` = []`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-05-29 15:16:38 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*(go to)(\s*)(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams($3, ['fromOrDialogName', 'dialogName']);
|
|
|
|
|
return `await dk.gotoDialog(${params})\n`;
|
2022-08-26 09:53:00 -03:00
|
|
|
|
}
|
2022-11-19 23:34:58 -03:00
|
|
|
|
];
|
2022-05-29 15:16:38 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(set language)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `await dk.setLanguage ({${$3}})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-08-26 09:53:00 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*set header\s*(.*)\s*as\s*(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2) => {
|
|
|
|
|
return `headers[${$1}]=${$2})`;
|
2022-08-26 09:53:00 -03:00
|
|
|
|
}
|
2022-11-19 23:34:58 -03:00
|
|
|
|
];
|
2022-05-29 15:16:38 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*set http username\s*\=\s*(.*)/gim,
|
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `httpUsername = ${$1}`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-08-05 00:10:23 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*set http password\s*\=\s*(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `httpPs = ${$1}`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-08-26 09:53:00 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(datediff)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams($3, ['date1', 'date2', 'mode']);
|
|
|
|
|
return `await dk.dateDiff (${params}})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-08-26 09:53:00 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(dateadd)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams($3, ['date', 'mode', 'units']);
|
|
|
|
|
return `await dk.dateAdd (${$3})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-11-06 15:23:56 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(set max lines)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `await dk.setMaxLines ({count: ${$3}})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-11-16 15:52:09 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(set max columns)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `await dk.setMaxColumns ({count: ${$3}})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-12-22 21:48:41 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(set translator)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `await dk.setTranslatorOn ({on: "${$3.toLowerCase()}"})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-11-20 13:44:18 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(set theme)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `await dk.setTheme ({theme: "${$3.toLowerCase()}"})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-11-20 13:44:18 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(set whole word)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `await dk.setWholeWord ({on: "${$3.toLowerCase()}"})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\w+)\s*\=\s*post\s*(.*),\s*(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `${$1} = await sys.postByHttp ({url:${$2}, data:${$3}, headers})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\w+)\s*\=\s*put\s*(.*),\s*(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `${$1} = await sys.putByHttp ({url:${$2}, data:${$3}, headers})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\w+)\s*\=\s*download\s*(.*),\s*(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `${$1} = await sys.download ({handle:page, selector: ${$2}, folder:${$3}})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-11-21 20:21:19 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\w+)\s*\=\s*CREATE FOLDER\s*(.*)/gim,
|
|
|
|
|
($0, $1, $2) => {
|
|
|
|
|
return `${$1} = await sys.createFolder ({name:${$2}})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-08-15 10:13:36 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*SHARE FOLDER\s*(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1) => {
|
|
|
|
|
return `await sys.shareFolder ({name: ${$1}})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*(create a bot farm using)(\s*)(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `await sys.createABotFarmUsing ({${$3}})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*(transfer to)(\s*)(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `await dk.transferTo ({to:${$3}})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\btransfer\b)(?=(?:[^"]|"[^"]*")*$)/gim,
|
|
|
|
|
() => {
|
|
|
|
|
return `await dk.transferTo ({})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-08-15 10:13:36 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(exit)/gim,
|
|
|
|
|
() => {
|
|
|
|
|
return ``;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-08-09 17:55:55 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(show menu)/gim,
|
|
|
|
|
() => {
|
|
|
|
|
return `await dk.showMenu ({})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-08-26 09:53:00 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*(talk to)(\s*)(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams($3, ['mobile', 'message']);
|
|
|
|
|
return `await sys.talkTo(${params})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-04-12 10:07:59 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*(talk)(\s*)(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
if ($3.substr(0, 1) !== '"') {
|
|
|
|
|
$3 = `"${$3}"`;
|
|
|
|
|
}
|
|
|
|
|
return `await dk.talk ({text: ${$3}})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-06-04 17:02:34 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(send sms to)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams($3, ['mobile', 'message']);
|
|
|
|
|
return `await sys.sendSmsTo(${params})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2021-08-21 09:18:28 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(send email)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams($3, ['to', 'subject', 'body']);
|
|
|
|
|
return `await dk.sendEmail(${params})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-05-03 17:05:57 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(send mail)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams($3, ['to', 'subject', 'body']);
|
|
|
|
|
return `await dk.sendEmail(${params})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-08-05 00:10:23 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(send file to)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams($3, ['mobile', 'filename', 'caption']);
|
|
|
|
|
return `await dk.sendFileTo(${params})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2019-03-08 06:37:13 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(hover)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams($3, ['handle', 'selector']);
|
|
|
|
|
return `await wa.hover (${params})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-07-13 09:38:13 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(click link text)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams('page,' + $3, ['handle', 'text', 'index']);
|
|
|
|
|
return `await wa.linkByText (${params})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(click)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
2022-12-26 13:37:11 -03:00
|
|
|
|
// page is not string.
|
|
|
|
|
// https://github.com/GeneralBots/BotServer/issues/310
|
2022-11-19 23:34:58 -03:00
|
|
|
|
const params = this.getParams('page,' + $3, ['handle', 'frameOrSelector', 'selector']);
|
|
|
|
|
return `await wa.click (${params})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-07-13 09:38:13 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(send file)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams($3, ['filename', 'caption']);
|
|
|
|
|
return `await dk.sendFile(${params})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2019-02-23 13:17:21 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(copy)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams($3, ['src', 'dst']);
|
|
|
|
|
return `await sys.copyFile (${params})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-05-19 10:22:22 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(convert)(\s*)(.*)/gim,
|
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams($3, ['src', 'dst']);
|
|
|
|
|
return `await sys.convert (${params})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2020-10-14 14:04:02 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\w+)\s*\=\s*(.*)\s*as chart/gim,
|
|
|
|
|
($0, $1, $2) => {
|
|
|
|
|
return `await dk.chart ({type:'bar', data: ${2}, legends:null, transpose: false})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*(chart)(\s*)(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
const params = this.getParams($3, ['type', 'data', 'legends', 'transpose']);
|
|
|
|
|
return `await dk.chart (${params})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*MERGE\s*(.*)\s*WITH\s*(.*)BY\s*(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `await sys.merge({file: ${$1}, data: ${$2}, key1: ${$3}})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*PRESS\s*(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2) => {
|
|
|
|
|
return `await wa.pressKey({handle: page, char: ${$1})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*SCREENSHOT\s*(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2) => {
|
|
|
|
|
return `await wa.screenshot({handle: page, selector: ${$1}})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*TWEET\s*(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2) => {
|
|
|
|
|
return `await sys.tweet({text: ${$1})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\w+)\s*\=\s*(.*)\s*as image/gim,
|
|
|
|
|
($0, $1, $2) => {
|
|
|
|
|
return `${$1} = await sys.asImage({data: ${$2}})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
|
|
|
|
/^\s*(\w+)\s*\=\s*(.*)\s*as pdf/gim,
|
|
|
|
|
($0, $1, $2) => {
|
|
|
|
|
return `${$1} = await sys.asPdf({data: ${$2})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*(\w+)\s*\=\s*FILL\s*(.*)\s*WITH\s*(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `${$1} = await sys.fill({templateName: ${$2}, data: ${$3}})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:36:18 -03:00
|
|
|
|
/^\s*save\s*(.*)\s*as\s*(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `await sys.saveFile({file: ${$2}, data: ${$1})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*(save)(\s*)(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2, $3) => {
|
|
|
|
|
return `await sys.save({args: [${$3}]})\n`;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
keywords[i++] = [
|
2023-01-04 16:26:18 -03:00
|
|
|
|
/^\s*set\s*(.*)/gim,
|
2022-11-19 23:34:58 -03:00
|
|
|
|
($0, $1, $2) => {
|
|
|
|
|
const params = this.getParams($1, ['file', 'address', 'value']);
|
|
|
|
|
return `await sys.set (${params})`;
|
|
|
|
|
}
|
|
|
|
|
];
|
2022-11-11 21:35:05 -03:00
|
|
|
|
return keywords;
|
2018-12-01 17:31:57 -02:00
|
|
|
|
}
|
|
|
|
|
|
2021-01-05 07:47:48 -03:00
|
|
|
|
/**
|
|
|
|
|
* Executes the converted JavaScript from BASIC code inside execution context.
|
|
|
|
|
*/
|
2022-11-19 23:34:58 -03:00
|
|
|
|
public static async callVM (text: string, min: GBMinInstance, step, GBDialogdeployer: GBDeployer, debug: boolean) {
|
2022-11-13 22:56:09 -03:00
|
|
|
|
const debuggerPort = 9222;
|
2021-01-13 13:36:44 -03:00
|
|
|
|
|
2021-01-05 07:47:48 -03:00
|
|
|
|
// Creates a class DialogKeywords which is the *this* pointer
|
|
|
|
|
// in BASIC.
|
2021-08-09 21:47:36 -03:00
|
|
|
|
|
2022-11-19 23:34:58 -03:00
|
|
|
|
const user = step ? await min.userProfile.get(step.context, {}) : null;
|
2022-06-06 18:03:02 -03:00
|
|
|
|
|
2022-11-02 19:40:59 -03:00
|
|
|
|
const sandbox = { user: user.systemUser };
|
2021-01-13 13:36:44 -03:00
|
|
|
|
|
2022-06-06 18:03:02 -03:00
|
|
|
|
const contentLocale = min.core.getParam<string>(
|
|
|
|
|
min.instance,
|
|
|
|
|
'Default Content Language',
|
|
|
|
|
GBConfigService.get('DEFAULT_CONTENT_LANGUAGE')
|
|
|
|
|
);
|
|
|
|
|
|
2022-08-01 18:36:45 -03:00
|
|
|
|
// Auto-NLP generates BASIC variables related to entities.
|
|
|
|
|
|
2022-06-21 17:46:46 -03:00
|
|
|
|
if (step && step.context.activity['originalText']) {
|
2022-11-19 23:34:58 -03:00
|
|
|
|
const entities = await min['nerEngine'].findEntities(step.context.activity['originalText'], contentLocale);
|
2022-06-07 18:37:29 -03:00
|
|
|
|
|
|
|
|
|
for (let i = 0; i < entities.length; i++) {
|
|
|
|
|
const v = entities[i];
|
|
|
|
|
const variableName = `${v.entity}`;
|
|
|
|
|
sandbox[variableName] = v.option;
|
|
|
|
|
}
|
2022-06-06 18:03:02 -03:00
|
|
|
|
}
|
|
|
|
|
|
2022-10-28 23:17:35 -03:00
|
|
|
|
const botId = min.botId;
|
|
|
|
|
const gbdialogPath = urlJoin(process.cwd(), 'work', `${botId}.gbai`, `${botId}.gbdialog`);
|
|
|
|
|
const scriptPath = urlJoin(gbdialogPath, `${text}.js`);
|
2021-01-13 13:36:44 -03:00
|
|
|
|
|
2022-10-22 13:23:32 -03:00
|
|
|
|
let code = min.sandBoxMap[text];
|
2021-01-05 07:47:48 -03:00
|
|
|
|
|
2022-11-02 16:03:25 -03:00
|
|
|
|
if (GBConfigService.get('VM3') === 'true') {
|
2022-10-28 23:17:35 -03:00
|
|
|
|
try {
|
|
|
|
|
const vm1 = new NodeVM({
|
|
|
|
|
allowAsync: true,
|
|
|
|
|
sandbox: {},
|
|
|
|
|
console: 'inherit',
|
|
|
|
|
wrapper: 'commonjs',
|
|
|
|
|
require: {
|
|
|
|
|
builtin: ['stream', 'http', 'https', 'url', 'zlib'],
|
|
|
|
|
root: ['./'],
|
|
|
|
|
external: true,
|
|
|
|
|
context: 'sandbox'
|
2022-11-19 23:34:58 -03:00
|
|
|
|
}
|
2022-10-28 23:17:35 -03:00
|
|
|
|
});
|
|
|
|
|
const s = new VMScript(code, { filename: scriptPath });
|
|
|
|
|
let x = vm1.run(s);
|
|
|
|
|
return x;
|
|
|
|
|
} catch (error) {
|
|
|
|
|
throw new Error(`BASIC RUNTIME ERR: ${error.message ? error.message : error}\n Stack:${error.stack}`);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
2022-11-19 23:34:58 -03:00
|
|
|
|
const runnerPath = urlJoin(
|
|
|
|
|
process.cwd(),
|
|
|
|
|
'dist',
|
|
|
|
|
'packages',
|
|
|
|
|
'basic.gblib',
|
|
|
|
|
'services',
|
|
|
|
|
'vm2-process',
|
|
|
|
|
'vm2ProcessRunner.js'
|
|
|
|
|
);
|
2022-10-28 23:17:35 -03:00
|
|
|
|
|
|
|
|
|
try {
|
2022-11-12 21:33:45 -03:00
|
|
|
|
const { run } = createVm2Pool({
|
|
|
|
|
min: 0,
|
|
|
|
|
max: 0,
|
2022-11-13 22:56:09 -03:00
|
|
|
|
debug: debug,
|
|
|
|
|
debuggerPort: debuggerPort,
|
2022-11-11 21:35:05 -03:00
|
|
|
|
botId: botId,
|
2022-10-28 23:17:35 -03:00
|
|
|
|
cpu: 100,
|
2022-11-02 16:03:25 -03:00
|
|
|
|
memory: 50000,
|
|
|
|
|
time: 60 * 60 * 24 * 14,
|
2022-10-28 23:17:35 -03:00
|
|
|
|
cwd: gbdialogPath,
|
|
|
|
|
script: runnerPath
|
|
|
|
|
});
|
|
|
|
|
|
2022-11-02 16:03:25 -03:00
|
|
|
|
const result = await run(code, { filename: scriptPath, sandbox: sandbox });
|
2022-11-19 23:34:58 -03:00
|
|
|
|
|
2022-11-02 16:03:25 -03:00
|
|
|
|
return result;
|
2022-10-28 23:17:35 -03:00
|
|
|
|
} catch (error) {
|
|
|
|
|
throw new Error(`BASIC RUNTIME ERR: ${error.message ? error.message : error}\n Stack:${error.stack}`);
|
|
|
|
|
}
|
2020-12-06 16:22:34 -03:00
|
|
|
|
}
|
2020-08-29 15:02:19 -03:00
|
|
|
|
}
|
2018-11-12 12:20:44 -02:00
|
|
|
|
}
|