It is recommended to use docker (https://github.com/openeyes/docker) or to use the install-system.sh and install-oe.sh located at https://github.com/openeyes/OpenEyes/tree/master/protected/scripts
This repo is still useful for installing OLD v1 and 2 versions of openeyes
This repository should be the only one checked out when building a new OpenEyes machine instance.
Disclaimer:
OpenEyes is provided under a GNU Affero General Public License v3 license and all terms of that license apply (https://www.gnu.org/licenses/agpl-3.0.html). Use of the OpenEyes software or code is entirely at your own risk. Neither the OpenEyes Foundation, ABEHR Digital Ltd nor any other party accept any responsibility for loss or damage to any person, property or reputation as a result of using the software or code. No warranty is provided by any party, implied or otherwise. This software and code is not guaranteed safe to use in a clinical environment and you should make your own assessment on the suitability for such use.
Index:
- Installing for Development or testing - using Vagrant and Virtual Box * Installing development environment on Mac OS X 10.6 or later hosts * Installing development environmant on Windows 7 or later hosts * Additional development tools
- SSH usage with github * Provisioning vagrant from private repos * Using SSH on a live install, or switching from HTTPS to SSH
- Installing for Live/Production use
- Management Tools
- Default connection and password info * Vagrant Virtual Machine Console * MySQL
The default development setup uses a Mac OSX (preferred) or Windows host, and runs a virtual server provided by VirtualBox with managed setup by Vagrant. Vagrant is not essential (see live use setup below) but offers a few advantages for developers, such as:
- Installs and configures a basic server for you
- Creates shared folders so code edited on the host is available directly on the virtual machine
- Maps the install directory on the host to /vagrant on the VM.
- Creates a host entry named openeyes.vm. So the website will be available at http://openeyes.vm and MySQL at openeyes.vm:3306
- [Virtualbox] Note that the site will also be NATted to http://localhost:8888 as an alternative, and localhost:3333 for MySQL
NOTE: These instructions assume you are installing in to a directory called ~/openeyes on the host. You may change this path as you see fit.
- Vagrant: https://www.vagrantup.com/downloads.html
- VirtualBox: https://www.virtualbox.org/wiki/Downloads
- Install Vagrant, VirtualBox and Git, following default install instructions from the above links.
- From a terminal window, change to your home directory. Run:
cd ~
- Clone OpenEyes/oe_installer to a directory of your choice. Run:
git clone [email protected]:openeyes/oe_installer.git
3.1 (note, you will need an SSH key configured first - see Setup SSH Key. Alternativey you can usegit clone https://github.com/openeyes/oe_installer
and then switch to SSH later on - Create the virtual server from your project directory. Run:
cd ~/oe_installer && vagrant up
- It will take 5 - 10 minutes for the install to complete (depending on the speed of your internet connection)
- At this point you should have a fully working OpenEyes server, reachable at http://localhost:8888
- You can follow the sections below on Additional development tools should you need them.
IMPORTANT: For this installer to run, the vagrant up command must be issued from a command window with elevated privileges (admin command prompt). This is due to a limitation with VirtualBox not being able to create symbolic links to shared folders unless it has admin rights. Failure to do this will result in unpredictable consequences!
NOTE: These instructions assume you are installing in to a directory called C:\oe_installer
on the host. You may change this path as you see fit. However, please note that Windows struggles with filenames longer than 275 characters on file shares, so keep this path below 30 characters. You can map a longer pathname to a drive letter using the subst command.
- Vagrant: https://www.vagrantup.com/downloads.html
- VirtualBox: https://www.virtualbox.org/wiki/Downloads
- Or Microsoft Hyper-V
- Install Vagrant, VirtualBox and Git, following default install instructions from the above links. 1.1 When installing git, choose to use bash tools, not the default Windows command prompt
- From an ADMINISTRATIVE command prompt window, change to your root directory.
Run:
cd c:\
- Clone OpenEyes/oe_installer.
Run:
git clone [email protected]:openeyes/oe_installer.git
3.1 (note, you will need an SSH key configured first - see Setup SSH Key. Alternativey you can usegit clone https://github.com/openeyes/oe_installer
and then switch to SSH later on - Change to the newly created oe_installer directory.
Run:
cd oe_installer
- Create the virtual server from your project directory.
Run:
vagrant up
5.1. If this is your first time running Vagrant, it may install some plugins first, then ask you to run again. In which case, runvagrant up
again to continue - It will take 5 - 10 minutes for the install to complete (depending on the speed of your internet connection)
- At this point you should have a fully working OpenEyes server, reachable at http://localhost:8888 (http://openeyes.mshome.net for HyperV)
If using the private repos, you will need to add your SSH key to your user account's .ssh folder BEFORE running vagrant up
. On windows this is %HOMEPATH%.ssh. On Mac and Linux this is ~/.ssh
Your SSH key should be named id_rsa or id_github, and it should be mapped to your gitgub user account (https://github.com/settings/keys).
IMPORTANT - Your SSH key must not have a password, otherwise it cannot be used in automated scripts
By Default, the installer will first try to use SSH, then fall back to HTTPS to connect to github. When using private repos without SSH, this means that you will be prompted for your username and password when running git pull, push, etc. Also note that if you use 2-Factor Authentication then HTTPS requires a special password. Therefore it is strongly recommended to use SSH
This section assumes you are installing OpenEyes on a virtual machine, (other than one built by Vagrant), a cloud server (such as AWS) or a physical server, and it is intended for non-development, and that your home directory is /home/me (you can modify accordingly).
- Install Ubuntu 18.04 LTS. Minimal installation, no software packages (except ssh server) (You are expected to know the root password and the username/password for your server).
- Log on as your normal user (presumed to be 'ubuntu' for this guide - amend as required)
- Run:
sudo apt install git
- Clone the openeyes repository to /var/www/openeyes. Run:
cd /var/www && git clone https://github.com/openeyes/oe_installer.git
- Run
export OE_MODE="LIVE"
- Run:
/var/www/openeyes/protected/scripts/install-system.sh
- Run:
/var/www/openeyes/protected/scripts/install-oe.sh
At this point you have a working server running on localhost (or your assigned IP address). You may wish to edit /etc/apache2/sites-available/000-default.conf
and set the ServerName directive to your chosen domain name (apache configuration knowledge required).
There is nothing to stop you from using this server configuration for development, by following the Default and Additional development tools sections above. However such use is outside our prescribed method for development.
Several additional terminal commands have been created for you in ``/usr/bin, to aid development. These can be run from any directory within the Virtual Machine (e.g, run
vagrant ssh` first). You should not run these commands as sudo.
- oe-which: tells you the current branch name for each of your code modules
- oe-checkout : will go through each code module and try to checkout the requested branch or version (e.g.,
oe-checkout v3.0
) - also runs oe-migrate to bring the newly installed database up to date - oe-update: will go through each code module and update (i.e. pull the latest) code
- oe-reset: will drop the current database and re-install it (also runs oe-migrate to bring the newly installed database up to date)
- oe-migrate: performs database migrations (normally used after a change to a newer code branch)
- oe-fix: performs a number of actions to put the code and data into a consistent state, updates dependencies and imports eyedraw configuration.
For example, to get the latest build and all database changes, you will need to run: oe-update
NOTE: Most of these commands provide a number of optional switches. Use oe- --help to see available options (e.g., oe-checkout --help
)
To login to the console of the vagrant VM, you'll need the following info.
This is the preferred method.
- From a terminal / admin command prompt, change directory to your oe_installer directory
- Run:
vagrant ssh
To login to the virtual Box machine directly use the following details:
- Username: vagrant
- Password: vagrant
Default access details for the MySQL Database are:
Port: 3306
Username: openeyes
Password: openeyes