# .gbapp Guide ## Introduction .gbapp is the folder extension for the General Bots Application package type. Anything inside a folder considered a .gbapp will be consumed by the server like a TypeScript application. This conversational application will contain the source code for custom dialogs and behaviour for any .gbot that associate this deployed .gbapp. ## Preparing Environment ### Windows 1. [Optional] Install [Chocolatey](https://chocolatey.org/install), a Windows Package Manager; 2. Install [git](`https://git-scm.com/`), a Software Configuration Management (SCM).; 3. Install [Node.js](npmjs.com/get-npm), a [Runtime system](https://en.wikipedia.org/wiki/Runtime_system); 4. Install Visual Studio Code Insiders, Brackets or Atom as an editor of your choice; 5. Fork the repository by visiting https://github.com/pragmatismo-io/BotServer/fork; 6. Clone the just forked repository by running `git clone /BotServer.git`; 7. Run `npm install -g typescript`; 8. Run the bot server by `gbot.cmd`. #### Recomended Chocolatey packages Please, note --confirm was added for convenience. ```cmd cinst git --confirm cinst nodejs --confirm npm install -g npm-check-updates cinst 7zip.install --confirm cinst tortoisegit --confirm cinst winscp --confirm cinst sysinternals --confirm cinst putty --confirm cinst pandoc --confirm cinst curl --confirm cinst micro --confirm cinst ccleaner --confirm cinst notepadplusplus --confirm cinst sql-server-management-studio --confirm ``` ![General Bots Inside Visual Studio Code provides a complete artificial intelligence based conversational platform](https://raw.githubusercontent.com/pragmatismo-io/BotServer/master/docs/images/general-bots-inside-visual-studio-code-provides-a-complete-artificial-intelligence-based-conversational-platform.png) ## Specifications ## Dialogs The dialog is built by specifing series of methods, disposed as an array as seen on Figure 1. Each dialog has also an identifier that can be called by several engines like kb.gbapp, which handles cloud based search for documents and other knowledge base information and also routes for the natural language processing (NLP) engine. ```typescript static getDialogs(bot: BotAdapter, min: GBMinInstance) { return [{name:"/convertTemperature", waterfall: [ async step => { }, async step => { }, async step => { }] },{name:"/convertCurrency", waterfall: [ async step => { }, async step => { }, async step => { }] } ] ``` *Figure 1 - How to build dialogs in General Bots using TypeScript* ## How To... ### Debugging .gbapp deployed on Azure 1. Visit https://.scm.azurewebsites.net/api/vfs/LogFiles/Application/index.html ## Tooling ### JavaScript | Título | Endereço | |--------|---------------------------------------------------------------------| | | https://deeplearnjs.org/ | | | Oimo.js http://lo-th.github.io/Oimo.js/\#stacking | | | js-sequence-diagrams: https://bramp.github.io/js-sequence-diagrams/ | | | http://blog.avenuecode.com/a-library-for-data-visualization-d3.js | | Chrome inside Node.js | https://github.com/GoogleChrome/puppeteer| | XLSX loader | https://github.com/mgcrea/node-xlsx | | Node.js bindings for CNTK | https://github.com/nadavbar/node-cntk | | API Repository | https://any-api.com/| | ORM | http://docs.sequelizejs.com/manual/tutorial/associations.html | Migração de .NET para JavaScript (Node.js) | https://www.reddit.com/r/webdev/comments/2val7s/as_a_net_developer_do_i_need_to_care_about_nodejs | | Simplified JavaScript Jargon | http://jargon.js.org | ### Packages | Título | Descrição | URL | |--------|---------------------------------------------------------------------|-----------------| | MSAL | Microsoft Authentication Library | https://www.npmjs.com/package/msal| ### Visual Studio Code Extensions | Title | Description | | ------|-------------| | mbinic.tgit-cmds | Set of commands for launching TortoiseGit dialogs | | tomashubelbauer.vscode-markdown-table-format | Formats MarkDown tables so that all columns have the same width | | esbenp.prettier-vscode | VS Code plugin for prettier/prettier (wraps at column 80) | | mikestead.dotenv | .env support |