Skip to content

Latest commit

 

History

History
89 lines (53 loc) · 5.97 KB

README.md

File metadata and controls

89 lines (53 loc) · 5.97 KB

Strautomator Web

This is Strautomator's web frontend, built with NuxtJS + Vuetify. It depends on the Strautomator Core to run. Please make sure you read the docs for the Core first before proceeding with the Web setup.

Settings

Strautomator is using the SetMeUp module to handle its settings, so for detailed info please check its docs. The settings are split as follows:

  • settings.json - settings shared by all environments, targeting production by default
  • settings.development.json - development settings, mostly when running on your dev machine
  • settings.production.json - production-only settings, except credentials and secrets (optional)
  • settings.secret.json - private credentials and secrets, excluded from the GIT repo
  • settings.local.json - private local-only settings, excluded from the GIT repo

Please note that the Core also has its own collection of settings files as well. If the same setting is define on the Core and on the Web, the Web settings has the higher priority.

Local setup

Before you try to get an instance running locally, make sure you have followed the Getting started instructions to have all the required 3rd party dependencies ready.

Cloning the code

First, create a folder on your machine that will server as the root all the Strautomator related components. Then proceed to clone this and the core repo and install all the necessary dependencies:

$ mkdir ~/strautomator
$ cd ~/strautomator
$ git clone [email protected]:strautomator/web.git
$ git clone [email protected]:strautomator/core.git
$ cd core
$ make update
$ cd ../
$ cd web
$ make update

Local settings

Make a copy of the settings.secret.json.sample and name it settings.secret.json. This is where you'll store all the credentials and sensitive keys. This file is encrypted automatically whenever the application starts up. You can also encrypt and decrypt on demand by using the $ make encrypt and $ make decrypt commands.

For other non-sensitive data, you can create a settings.local.json. This file is kept in clear text on your local machine.

Setting the URL

The default URL in development is http://localhost:3000, which should be manually set on your HOSTS file. This is fine if you only want to work on the web frontend and some of the API calls, but please note that Strava (and other 3rd party webhooks) won't be able to push data to the service using that URL. Authentication with Strava might also fail.

To properly test all APIs and webhooks from Strava and PayPal, you'll need to change the app.url setting on your settings.local.json file or preferably via the $SMU_app_url environment variable, to a publicly accessible URL. It's recommended to use a tunnel to avoid port forwarding on your router.

If for whatever reason you want to split the Strautomator API from the frontend, you can use the api.url setting to specify the base path for the API. By default, it runs on the /api/ path under the same URL set on the app.url.

If you plan to deploy the instance to production and build the nuxt app beforehand, it's mandatory to set the app URL via the environment variable $SMU_app_url.

Cloudflare Tunnel

The easiest way to get the web frontend running and accessible with SSL is by using a tunnel. By default the app will try opening a tunnel with Cloudflare when running on dev, but you'll need to setup the tunnel manually first. Instructions can be found here.

To disable the tunnel execution, set the app.tunnel setting to false on the settings.local.json file.

Server ports

When starting up, the service will look for the strautomator.cert and strautomator.key files on the application root. If found, it will create a HTTPS server with those certificate files, otherwise it will create a regular HTTP server. The default ports:

  • Development: 3000
  • Production (HTTP): 8080
  • Production (HTTPS): 8443

Please note that the actual port can be overwritten either via the PORT environment variable, or via settings.app.port setting.

Running it locally

As simple as:

$ make run

If any required settings are missing or wrongly set, you'll get alerted on the console. When running locally (NODE_ENV is development), all features dependent on scheduled functions will run at startup.

Deployment

Strautomator is targeting GCP and can be easily deployed as a standalone VM instance, as a Cloud Run service, or to App Engine. Although you could also run it on other providers (AWS for instance), please keep in mind that the database, Cloud Firestore, runs on Google.

Also note that even thou this project is open source, you might need to adapt some settings if you want to run it in production on your own cloud environment. This includes changing the target URL (https://strautomator.com/), server IP and ports, HTMLs with references to strautomator.com, etc.

Basic deployment samples are provided:

  • App Engine: app.yaml (not tested in production).
  • VM in Google Cloud Compute: docker-compose.yml (not tested in production).
  • Cloud Run: create a Cloud Build trigger to update your service whenever there's a new version pushed to your GIT fork.

Scheduled functions

Please note that some features depend on scheduled functions to work. These can be found here, and need to be deployed separately to your environment of choice.