Orion provides a minimal, single-user server deployment of Orion written in JavaScript that runs on Node.js. This implementation of Orion supports developing your own Node applications with Orion's editing environment.

Features

The JavaScript Orion server implementation is still very early access. There are many rough edges and missing features compared to the full Java-based Orion server. The JavaScript-based Orion server currently supports:

Requirements

Getting Orionode and starting it

You can obtain Orionode through npm (the easiest way) or by checking out its source repo and running it. Checking out the source is mainly of interest to developers wishing to work on or extend the Orion node server. For details on this approach see the Orion developer wiki page.

Installing with npm

To install Orion with the Node Package Manager (npm), simply run the following command from the shell:

Run this command from a shell: npm install orionThis should install Orionode into a node_modules subdirectory of your working directory.

If you're not interested in developing the Orionode server, add the --production flag for a slightly smaller download.

Starting and stopping the server

Launch Orion by running:npm start orion

If you need to pass command line arguments to the server, run the server.js file directly:node node_modules/orion/server.js [arguments]

Go to http://localhost:8081 (or whatever port you provided in the server arguments) in your web browser to start using Orionode.

Stop the server by sending a kill signal from the console (typically Ctrl+C)

The orion.conf file

You can pass arguments to the server by editing the orion.conf file. It is found in the directory where you installed Orion (when installing from npm, this is typically node_modules/orion/).

Password

Add a line in your orion.conf file that looks like this:

pwd=mysecretpassword

Workspace

Edit the orion.conf file and change the workspace option to point to a directory in your user space. If not specified, a default .workspace directory will be created in the Orion install directory. For example:

workspace=/home/pi/Workspace/

Making sure Orion can launch npm

Orion on Node lets you use npm commands in the Orion shell to manage the dependencies of a project you're writing. To do this, the server makes a guess about the path where the npm internals (specifically, npm-cli.js) are located on your computer. If you installed a recent version of Node.js, npm should be installed automatically and the guess should work. If you installed npm separately, this guess may be wrong. If you see an error message when launching the server or when you try to run npm commands in the Orion shell, it means the server failed to guess where npm lives, so you have to specify the path to npm-cli.js yourself:

Find out where npm lives on your computer (npm must be in your PATH environment variable for this to work). From a command shell, run:

On Windows: where npm

On Mac OS/Linux: which npm

The returned path will be a shell script (or a symbolic link to a script) that launches npm-cli.js. The path to npm-cli.js is what we need. Open up the script in a text editor, and copy the path of npm-cli.js.

In the server directory, open the orion.conf file. You'll find a npm_path option (by default its value is empty).

Set the value of npm_path option equal to the path to npm-cli.js.

You can provide the path as an absolute path, or a path relative to your node executable.

Start or restart the server. If you do not see any "npm" errors printed to the console, your npm path is set properly.

Server command line arguments

When launching the server manually through node.js (node [orion install dir]/server.js), a number of optional arguments can be provided:

-p or -port

The port that the Orion server will listen on. Defaults to 8081.

-pwd or -password

Path to a file containing a password. If provided, Orionode will enforce HTTP Basic Authentication with the password (the auth 'User' field is ignored -- Orionode only verifies the password). Use caution: if you don't provide a password file, no authentication is used (so anyone can access your Orionode server and read and write your files!).

-w or -workspace

The target directory for reading and writing files. Will be created if it doesn't exist. Defaults to a subdirectory named .workspace in the server directory. This option can also be set in your orion.conf file.

-dev

Starts the server in development mode. In this mode, some client-side code is not cached by the browser, to ease development.

-log

Logs each request served to standard output.

Arguments passed on the command line override arguments set in the orion.conf file, when both are provided.

Developing a node.js application

Now in the browser you can start to develop your node.js applications. Orionode uses largely the UI you're accustomed to from Orion. (Refer to Orion user guide for basic instructions). Please note that the Sites and Git pages are not available in Orionode. Here is a typical workflow:

Use the Navigator and Edit pages to create and edit your folders and node applications.

Go to the Shell page.

cd to the folder where your application lives.

Use npm install to install your dependency packages if needed. You can use basically all the npm arguments here.

Use node start yourApp.js to start your application.

Use node list to monitor any long-running applications you've started.

Use node stop [PID] to stop an application if you want to force it to stop.

Debugging a node.js application

You can use Orionode to debug your node.js application. If you have existing node.js applications, make sure the code is under a subfolder of the workspace (path provided by the -w option when you start Orionnode). This will give you easy access to your node.js apps from within Orionode.
You can also create a new node.js application in your workspace.

After Orionode starts, open the shell page and use help to see what commands are available.

cd to the folder where your application lives.

Use node debug yourApp.js givenPort to start your app in debug mode. You can start multiple apps in debug mode by repeating this step.

In the return value of the node debug command, you will see a "Debug URL", which you can click to start debugging your app.

The debug interface currently only works with Webkit browsers (Chrome, Safari).

Other ways of using Orionode

You can use Orionode as a file server, to access your local files from http://www.orionhub.org/ (or any other Orion installation). All you need is
Orionode and a publicly-accessible URL pointing to your local Orionode server.