This page contains most basic information about BENJA and its usage. Please note that every supported board might have slightly different setup, hardware acceleration capabilities, or setup.
Debian / Ubuntu users
Please install the following before proceeding with the installation:
sudo apt install curl libarchive-tools
Other distro/OS dependencies
This is the list of command line utilities used by the installer: bsdtar
, curl
, fdisk
, lsbklk
, mkfs
, parted
, and sudo
.
If your environment has these utilities and a bash
terminal, you should be able to prepare an SD card.
How to create the B.E.N.J.A. environment
All you need to do, is type the following in your ArchLinux terminal, and follow the instructions:
bash <(curl -s https://archibold.io/benja/prepare)
How to Develop
Creating applications is as easy as writing the following from the APP
disk folder:
$ npm start
This is indeed what gets executed once Benja OS starts, except it’ll have sudo
privileges to be able to use GPIO.
If you’d like to develop remotely, write the following in console, substituting x
with your values (to know which IP address your card has, type ip addr
in its terminal once connected):
$ ssh [email protected]
password: xxxxxxxx
At this point you can use nano ~/app/index.js
to edit that file or, if your IDE supports it, you can use rmate which is already available in Benja OS.
This gives you the ability to also test directly GPIO related operations through the board.
How to reload the App
There are at least a couple of ways to do it: remotely and directly through the app.
The default app example uses a watcher on its main index.js
file:
// for debugging purpose, it might be handy to be able
// to reload the window simply via `touch ~/app/reload`
require('fs').watch('reload', () => app.quit());
Once logged in via ssh
all you need to do is to write the following:
touch ~/app/reload
This will quit the app and thanks to BenjaOS configuration it will also restart it. Alternatively you could put a simple script on the page such:
<script>
// set double click handler and reload the page if triggered
document.documentElement.ondblclick = () => location.reload();
</script>
It could be any sort of event, or a combination of keys, a gesture, a button.
Bear in mind you could even spawn
a reboot
via bash or shell, or even invoke a shutdown -h now
: you have full control.
How to load the app remotely
By default, BenjaOS redirects to port 8080
all calls to port 80
, making it simple to use from your browser the same index.html
.
Write http://192.168.1.x
on your browser, being sure the it is the one assigned to your board, and verify everything is OK.
However, if you plug the SD card into your laptop, you can simply run npm start
on BENJA-APP folder and develop directly in there.
Ctrl + Shift + I
to eventually bring up the console and debug like any other HTML page.
Remember, Electron runs with super powers only via the board, not when its site is reached remotely.
How to not boot the App
If you’d like to play around with Arch Linux instead
of booting the app, you can either rename ~/app/package.json
into ~/app/package.jsno
or ~/app/package.jsoff
,
or you could remove it or rename it differently, like ~/app/package.nope
.
This will inform Benja OS that it should just boot in the first available terminal, either on Weston or X11.
How to install App dependencies
If you remove the folder ~/app/node_modules
, Benja will install production only dependencies, without binaries links, automatically next time it starts.
The reason bin-links are not allowed, is that carrying the SD card around would not find those, but it’s handy to have all dependencies that don’t require bin links or build steps into the APP folder.
Every dependency that might need bin links or build steps should be saved into the user home ~/
folder, in your SBC, and eventually globally in your development machine.
As example, raspi-io
or johnny-five
are already installed in ~/node_modules
, so you don’t need to worry about building these against your SBC.
How to include node modules
Due some limitation with current Electron paths, your application might need to include the benja module on top.
// on top of index.js or index.html
// to have access to both local and global modules
require(process.cwd() + '/node_modules/benja').paths();
In alternative, you need to specify manually paths via:
[].push.apply(
require('module').globalPaths,
[process.cwd() + '/node_modules']
.concat(process.env.NODE_PATH.split(':').filter(p => 0 < p.length))
);
How to Update Benja OS
Being simply a specially configured Arch Linux ARM OS, all you need to update the system is the following:
# updates ArchLinux to the latest
sudo pacman -Syu
You can use npm update
too, if needed, in the ~/
or ~/app
folder.
Known Issues
- electron: for some reason Electron starts leaving 1 pixel width and height off. If you have any idea how to fix that, please share, thanks.
- wifi: in some case, Raspberry Pi Zero W might let you configure the WiFi properly, but then it’ll ask again to configure it. If that’s the case, unplug the Raspberry, wait a minute, then switch it on again, as I haven’t found yet the culprit of this issue. However, once BENJA has been setup, the WiFi connection on boot seems to be stable.