Powered by Tachyonic Project Luxon Framework v0.0.0


This tutorial will walk through a basic deployment of Photonic in an Ubuntu environment, using Luxon to install Photonic and it's two dependencies: Infinitystone and Psychokinetic. We will launch an Apache WebServer and install these componets on it. We will be able to use the Psychokinetic API through direct calls or via the Photonic gui which will be displayed in our browser.


Check your python installation, Tachyonic needs python 3.5 or 3.6

$ python3 --version
    Python 3.5.2

We will be using pip3 to install Tachyonic's modules. It should already be installed in the Python 3 binaries

$ pip3 --version
    pip 8.1.1 from /usr/lib/python3/dist-packages (python 3.5)

Now let's install some prerequisites

$ apt-get update
$ apt-get --assume-yes install apache2
$ apt-get --assume-yes install apache2-dev
$ apt-get --assume-yes install apache2-utils
$ apt-get --assume-yes install libcurl4-openssl-dev libssl-dev
$ apt-get --assume-yes install python3
$ apt-get --assume-yes install python3-dev
$ apt-get --assume-yes install python3-pip
$ apt-get --assume-yes install git
$ apt-get --assume-yes install sqlite3
$ apt-get --assume-yes install libapache2-mod-wsgi-py3
$ apt-get clean
At this point you should have all the required dependencies and a running Apache webserver.
Navigate to the local host to see the Apache2 Ubuntu Default Page


Currently the only way to install the modules is to compile from the source code, luckily this is very easy.

The relevant source code is all hosted on github, let's clone it. This tutorial will clone it into the root directory by default.

$ cd /root
$ git clone -b development https://github.com/TachyonicProject/luxon.git
$ git clone -b development https://github.com/TachyonicProject/psychokinetic.git
$ git clone -b development https://github.com/TachyonicProject/photonic.git
$ git clone -b development https://github.com/TachyonicProject/infinitystone.git

Next we'll install the modules from the source code with pip3 so that they can be used in python

$ cd /root/luxon
$ pip3 install -r requirements.txt
$ pip3 install .
$ cd /root/psychokinetic
$ pip3 install .
$ cd /root/photonic
$ pip3 install .
$ cd /root/infinitystone
$ pip3 install .

Now it's time to deploy Photonic and Infinitystone in our Apache webserver

We'll navigate to /var/www and make directories Infinitystone and Photonic

$ cd /var/www
$ mkdir infinitystone
$ mkdir photonic

First let's deal with Infinitystone:

We will use Luxon to install Infinitystone with the -i command

$ luxon -i infinitystone infinitystone

Luxon can also set up the database for Infinitystone by using the -d command

$ luxon -d infinitystone

Set the user and group, we'll call them each "www-data"

$ chown -R www-data:www-data infinitystone

And set the permissions for the database file

$ chmod 770 infinitystone/sqlite3.db

We need to rename the database to "tachyon"

$ mv infinitystone/sqlite3.db infinitystone/tachyon

The Infinitystone installation needs a copy of the settings.ini and policy.json files which. So we will create symbolic links to the original files to get around this.

$ ln -s /root/infinitystone/infinitystone/settings.ini infinitystone/settings.ini
$ ln -s /root/infinitystone/infinitystone/policy.json infinitystone/policy.json

Now let's repeat the process for Photonic:

Install with Luxon.

$ luxon -i photonic photonic

The Photonic installation creates a file: static incorrectly, we need to remove and replace with a symbolic link to the file in the source code

$ rm -rf photonic/static
$ ln -s /root/photonic/photonic/static/ photonic/static

And as before link to the settings.ini/policy.json files

$ ln -s /root/photonic/photonic/settings.ini photonic/settings.ini
$ ln -s /root/photonic/photonic/policy.json photonic/policy.json

Both modules need tmp directories to store session data

$ mkdir infinitystone/tmp
$ mkdir photonic/tmp

Set the user:group for those to "www-data" as well

$ chown -R www-data:www-data infinitystone/tmp
$ chown -R www-data:www-data photonic/tmp

Both modules need a pki certificate. We'll create it in Infinitystone

$ cd /var/www/infinitystone
$ openssl req  -nodes -new -x509  -keyout token.key -out token.cert -subj "/C=ZA/ST= /L= /O= /OU= /CN= "

And we'll just link it to Photonic

$ ln -s ../infinitystone/token.cert ../photonic/token.cert

We will give Photonic's static dirctory to the webserver so that we can interface with Tachyonic via a browser. Again with a symbolic link

$ ln -s /root/photonic/photonic/static/ /var/www/html/static

Finally download a sample apache .config file, give it to our web server and reload Apache for this new file to take effect

$ cd /etc/apache2/sites-enabled/
$ wget https://raw.githubusercontent.com/TachyonicProject/photonic/development/photonic/resources/000-default.conf
$ sudo service apache2 reload

At this point we should have a working instilation of Photonic. To view it browse to and log in with

username: root
password: password

Code Updates

Code Update: tachyonic-sphinx/master Fixed spelling mistake
2018-04-18 18:13:03 (UTC)
Code Update: netrino/development Start Element manager
2018-04-18 11:45:47 (UTC)
Code Update: photonic/development User Role assignment now makes use of select2 with AJAX call for fast…
2018-04-10 11:29:10 (UTC)
Code Update: psychokinetic/development removed private test code
2018-04-08 11:03:35 (UTC)
Code Update: psychokinetic/development api updates features for psychokinetic
2018-04-08 11:01:23 (UTC)
Code Update: psychokinetic/development Github restapi updates...
2018-04-04 09:34:09 (UTC)
Code Update: photonic/development issues with new menu mods - using old one for now
2018-03-28 12:09:58 (UTC)
Code Update: photonic/development updated top, account and service menu to responsive design which cate…
2018-03-28 11:54:28 (UTC)
Code Update: psychokinetic/development fixed bug in get_header for client middleware for token
2018-03-28 10:50:35 (UTC)
Code Update: infinitystone/development Fized bug where date object can not be json dumped
2018-03-23 10:14:36 (UTC)
Code Update: infinitystone/development Reverting last change
2018-03-22 07:59:12 (UTC)
Code Update: infinitystone/development Users can now log into any domain they have a role on
2018-03-22 07:23:08 (UTC)