Skip to content
This repository has been archived by the owner on Jun 27, 2024. It is now read-only.

Latest commit

 

History

History
40 lines (25 loc) · 3.43 KB

File metadata and controls

40 lines (25 loc) · 3.43 KB

Getting Started with Apps-Engine

{% hint style="warning" %} Throughout the entire process, an active Internet connection is required. {% endhint %}

Prerequisites

Before beginning, the following must be installed on your machine:

To develop a Rocket.Chat App, you must write TypeScript code. Although the Apps-Engine CLI manages the majority of definitions, you must grasp where the code guides you to comprehend how your application interacts with the Rocket.Chat server and external APIs.

About Rocket.Chat Server

To test your applications, you will need an active server. Ideally, this would be a test environment not to impact the production environment. The following components are related to the Rocket.Chat server and there is no action required from your end:

  • Server Management and Package Manager: To develop a full-stack JavaScript application, a server-side JavaScript runtime is required. Additionally, you will need a package manager. You can use Node.js as your server environment, as it can serve files and connect to your database using JavaScript. As for the Package Manager, we recommend using Yarn because it can install libraries more quickly and is a secure, dependable JavaScript dependency management tool.
  • Database: You need a database to store your application data. The Rocket.Chat server uses MongoDB as a database to store all chat messages, user information, and other system configurations and related data.

About Node.js VM Module

Node.js is a cross-platform, open-source JavaScript runtime environment extensively used to develop server-side and networking applications. Node.js is designed on top of Chrome's V8 engine, allowing developers to run Javascript programs exceptionally quickly by compiling them directly to machine code.

The virtual machine (VM) module is a fundamental feature of Node.js that allows developers to execute programs in a VM context. The VM module provides access to APIs for compiling and executing code within the context of a V8 VM. The Rocket.Chat Apps-Engine is built on top of the Node.js VM module; therefore, most of the environment configuration will involve launching the VM module within your Rocket.Chat workspace.

About Context

With the help of the VM module, a context is an alternative environment that is created. This environment consists solely of key-value pairings, each of which runs directly on top of the V8 engine.

The aim of using the Node.js VM module was to isolate each app on its own scope, preventing them from interacting directly with the host Rocket.Chat server or other apps, so they couldn't inject data and disrupt the system or expose data from other sources. In addition, it is also to avoid the complication of spawning, controlling, and managing the communication of external processes to execute these logics.

{% hint style="info" %} Note: The app doesn't have direct access to the VM's APIs. This information is for your understanding. {% endhint %}