Skip to content

Commit

Permalink
feat(gbdialog): The first VBA code is run.
Browse files Browse the repository at this point in the history
  • Loading branch information
Rodrigo Rodriguez (pragmatismo.io) committed Nov 30, 2018
1 parent 9379dec commit f0a0cd3
Show file tree
Hide file tree
Showing 6 changed files with 118 additions and 60 deletions.
9 changes: 6 additions & 3 deletions packages/core.gbapp/services/GBAPIService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,14 +47,15 @@ export class DialogClass {
this.min = min;
}

public async hear(text: string): Promise<any> {
// await this.context.beginDialog('textPrompt', text);
public hear(text: string) {
// TODO: await this.context.beginDialog('textPrompt', text);
}

public talk(text: string) {
this.context.sendActivity(text);
}


/**
* Generic function to call any REST API.
*/
Expand All @@ -66,5 +67,7 @@ export class DialogClass {
/**
* Generic function to call any REST API.
*/
public post(url: string, data) {}
public post(url: string, data) {

}
}
3 changes: 2 additions & 1 deletion packages/core.gbapp/services/GBMinService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -484,7 +484,8 @@ export class GBMinService {
// Checks for /admin request.
if (context.activity.text === 'vba') {
min.sandbox.context = context;
min.sandbox['chat'](min.sandbox);
min.sandbox['bot'].bind(min.sandbox);
min.sandbox['bot']();
} else if (context.activity.text === 'admin') {
await step.beginDialog('/admin');

Expand Down
40 changes: 32 additions & 8 deletions packages/core.gbapp/services/GBVMService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36,10 +36,12 @@ import { GBMinInstance, IGBCoreService } from 'botlib';
import * as fs from 'fs';
import { DialogClass } from './GBAPIService';
import { GBDeployer } from './GBDeployer';
import { TSCompiler } from './TSCompiler';
const util = require('util');
const logger = require('../../../src/logger');
const vm = require('vm');
const UrlJoin = require('url-join');
const vb2ts = require('vbscript-to-typescript/dist/converter');

/**
* @fileoverview Virtualization services for emulation of BASIC.
Expand All @@ -55,16 +57,38 @@ export class GBVMService implements IGBCoreService {
deployer: GBDeployer,
localPath: string
): Promise<void> {
const path = 'packages/default.gbdialog';
const file = 'bot.vbs';
const source = UrlJoin(path, file);

localPath = UrlJoin(localPath, 'bot.vbs.js');
const code: string = fs.readFileSync(localPath, 'utf8');
const sandbox: DialogClass = new DialogClass(min);
const context = vm.createContext(sandbox);
vm.runInContext(code, context);
// Example when handled through fs.watch() listener
fs.watchFile(source, async (curr, prev) => {
await this.run(source, path, localPath, min, deployer, filename);
});
await this.run(source, path, localPath, min, deployer, filename);
}

private async run(source: any, path: string, localPath: string, min: any, deployer: GBDeployer, filename: string) {
// Converts VBS into TS.

await deployer.deployScriptToStorage(min.instanceId, filename);
logger.info(`[GBVMService] Finished loading of ${filename}`);
vb2ts.convertFile(source);

min.sandbox = sandbox;
// Convert TS into JS.
const tsfile = `bot.ts`;
const tsc = new TSCompiler();
tsc.compile([UrlJoin(path, tsfile)]);
// Run JS into the GB context.
const jsfile = `bot.js`;
localPath = UrlJoin(path, jsfile);
if (fs.existsSync(localPath)) {
let code: string = fs.readFileSync(localPath, 'utf8');
code = code.replace(/^.*exports.*$/gm, '');
const sandbox: DialogClass = new DialogClass(min);
const context = vm.createContext(sandbox);
vm.runInContext(code, context);
min.sandbox = sandbox;
await deployer.deployScriptToStorage(min.instanceId, filename);
logger.info(`[GBVMService] Finished loading of ${filename}`);
}
}
}
74 changes: 74 additions & 0 deletions packages/core.gbapp/services/TSCompiler.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
/*****************************************************************************\
| ( )_ _ |
| _ _ _ __ _ _ __ ___ ___ _ _ | ,_)(_) ___ ___ _ |
| ( '_`\ ( '__)/'_` ) /'_ `\/' _ ` _ `\ /'_` )| | | |/',__)/' _ `\ /'_`\ |
| | (_) )| | ( (_| |( (_) || ( ) ( ) |( (_| || |_ | |\__, \| ( ) |( (_) ) |
| | ,__/'(_) `\__,_)`\__ |(_) (_) (_)`\__,_)`\__)(_)(____/(_) (_)`\___/' |
| | | ( )_) | |
| (_) \___/' |
| |
| General Bots Copyright (c) Pragmatismo.io. All rights reserved. |
| Licensed under the AGPL-3.0. |
| |
| 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, |
| but WITHOUT ANY WARRANTY, without even the implied warranty of |
| 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. |
| |
\*****************************************************************************/

/**
* @fileoverview General Bots server core.
*/

'use strict';

import * as ts from 'typescript';
const logger = require('../../../src/logger');

export class TSCompiler {
public compile(
fileNames: string[],
options: ts.CompilerOptions = {
noEmitOnError: false,
noImplicitAny: true,
target: ts.ScriptTarget.ES5,
module: ts.ModuleKind.None,
moduleResolution: ts.ModuleResolutionKind.Classic,
noEmitHelpers: true,
maxNodeModuleJsDepth: 0,
esModuleInterop: false

}
) {
const program = ts.createProgram(fileNames, options);
const emitResult = program.emit();

const allDiagnostics = ts.getPreEmitDiagnostics(program).concat(emitResult.diagnostics);

allDiagnostics.forEach(diagnostic => {
if (diagnostic.file) {
const { line, character } = diagnostic.file.getLineAndCharacterOfPosition(diagnostic.start!);
const message = ts.flattenDiagnosticMessageText(diagnostic.messageText, '\n');
logger.error(`${diagnostic.file.fileName} (${line + 1},${character + 1}): ${message}`);
} else {
logger.error(`${ts.flattenDiagnosticMessageText(diagnostic.messageText, '\n')}`);
}
});

return emitResult;
}
}
12 changes: 4 additions & 8 deletions packages/default.gbdialog/bot.vbs
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
<%

'****************************************************************************
' ( )_ _
' _ _ _ __ _ _ __ ___ ___ _ _ | ,_)(_) ___ ___ _
Expand Down Expand Up @@ -31,13 +30,10 @@
' our trademarks remain entirely with us.
'
'****************************************************************************

function ICanSendEmails()

bot.say ("Please, what's your e-mail address?")
email = bot.expectEmail()
bot.sendMail (email, "Hello", "I'm sending a General Bots VBA e-mail.")

end function
this.talk ("Please, what's your e-mail address?")
let email = this.hear()
this.talk("Thanks, sending e-mail to: " + email);
this.sendEmail(email, "Message from VBA Bot", "Yes, I can send e-mails.");

%>
40 changes: 0 additions & 40 deletions packages/default.gbdialog/bot.vbs.js

This file was deleted.

0 comments on commit f0a0cd3

Please sign in to comment.