Go to file
Chris Veilleux cd2e4248b5 bugfix for adding first device to a new account 2022-11-21 16:22:33 -06:00
.github Adding Apache 2.0 license and such 2019-08-12 15:28:52 -05:00
e2e Adding Apache 2.0 license and such 2019-08-12 15:28:52 -05:00
projects bugfix for adding first device to a new account 2022-11-21 16:22:33 -06:00
src Merge remote-tracking branch 'origin/dev' into test 2022-09-16 13:45:57 -05:00
.browserslistrc upgrade angular material to version 10 2020-09-28 12:34:44 -05:00
.dockerignore changed dockerfile to take an argument specifying which project to build 2018-11-12 22:24:04 -06:00
.editorconfig Moved marketplace UI into the a new angular workspace that will hold all selene angular projects 2018-10-31 15:42:36 -05:00
.gitignore updated to angular 12 2022-07-21 12:17:32 -05:00
AUTHORS Adding Apache 2.0 license and such 2019-08-12 15:28:52 -05:00
CODE_OF_CONDUCT.md Adding Apache 2.0 license and such 2019-08-12 15:28:52 -05:00
Dockerfile added step to build the globalnav project before the application 2018-11-14 16:28:02 -06:00
Jenkinsfile remove precise from automated build as it is not a finished product 2022-10-17 19:36:28 -05:00
LICENSE.md Adding Apache 2.0 license and such 2019-08-12 15:28:52 -05:00
README.md First draft of installation and running instructions to readme 2019-08-17 17:50:25 -05:00
angular.json bugs found testing new material design interface 2022-08-03 13:26:34 -05:00
package-lock.json update social login library to allow for new google sign in method 2022-10-14 14:36:12 -05:00
package.json update social login library to allow for new google sign in method 2022-10-14 14:36:12 -05:00
tsconfig.json updated to angular 14 2022-07-21 12:17:33 -05:00
tslint.json upgrade angular material to version 10 2020-09-28 12:34:44 -05:00

README.md

License CLA Team Status

PRs Welcome Join chat

Selene -- Mycroft's Web Backend

Selene provides the services used by Mycroft Core to manage devices, skills and settings. It consists of two repositories. This one contains GUI web applications built using the Angular framework. data access layer, APIs and scripts. The second repository, Selene Backend, contains Python and SQL representing the database definition,data access layer, APIs and scripts that support the web applications defined in this repository.

There are three web applications defined in this repository, account management single sign on, and skill marketplace. Each application is designed to run independently of the others. This repository also includes two libraries containing code common to each of the applications.

Installation

These instructions assume that the APIs and databases in the Selene Backend repository have been installed. The README file in that repository contains the necessary instructions. As with the Selene Backend repository, these instructions will also assume that each application (API & GUI) will run on an independent server or virtual machine. Running Selene on a single server is possible. Many of the instructions below are also applicable to running on a single server. The biggest difference being that all the compiled code will live on the same server.

To eliminate redundantly downloading and building the code on each server, it is recommended to do so on a build host. Once the build is complete, copy the compiled code to the servers that will run the applications. This repository includes a Jenkinsfile that builds the code and deploys it via ssh. It can be altered to work with any Jenkins instance.

  • Install Angular 7 and node.js on your build host.
  • Download this repository to your build host. The simplest method is via git (git installation instructions)
cd <directory of your choice>
git clone https://github.com/MycroftAI/selene-ui.git
cd selene-ui
  • Install the required node.js packages
npm install
  • Compile the Angular Typescript code. By default the code is compiled into the selene-ui/dist directory
ng build --project shared
ng build --project globalnav
ng build --project account --prod
ng build --project market --prod
ng build --project sso --prod
  • Copy the compiled code to the /var/www directory on the servers. The shared and globalnav modules are libraries that need to be copied to all servers. The account, market and sso modules need only be copied to their respective servers.

Running the Web Applications

  • Install a web server on each of the application servers. Configure the web server to serve the index.html file of the web application.
    Instructions on how to do this will vary depending on web server used. See the software provider's documentation for detailed instructions.
  • Add the web applications to the reverse proxy that is already being used for the APIs in the Selene Backend repository.

Getting Involved

This is an open source project and we would love your help. We have prepared a contributing guide to help you get started.

If this is your first PR or you're not sure where to get started, say hi in Mycroft Chat and a team member would be happy to mentor you. Join the Mycroft Forum for questions and answers.