Skip to content

Latest commit

 

History

History
189 lines (143 loc) · 8.61 KB

README.md

File metadata and controls

189 lines (143 loc) · 8.61 KB

Core Building Block

The Core Building Block handles core functions for the Rokwire platform - users, accounts, profiles, applications, organizations, configurations, authentication, and authorization.

Architecture

The service is based on clear hexagonal architecture. The hexagonal architecture divides the system into several loosely-coupled components, such as the application core and different adapters. We categorize the adapters in two categories - driver and driven.

core

This is the core component of the service. It keeps the data model and the logic of the service. It communicates with the outer world via adapters.

driver adapters

What the service provides - user interface, rest adapter, test agent etc.

driven adapters

What the service depends on - database, mock database, integration with other services etc.

Documentation

The functionality provided by this application is documented in the Wiki.

The API documentation is available here: https://api.rokwire.illinois.edu/core/doc/ui/index.html

Set Up

Prerequisites

MongoDB v4.2.2+

Go v1.22+

Environment Variables

The following Environment variables are supported. The service will not start unless those marked as Required are supplied.

Name Format Required Description
ROKWIRE_CORE_LOG_LEVEL < string > no Logging level to be printed to the console. Options are Info, Debug, Warn, and Error. Defaults to Info.
ROKWIRE_CORE_ENVIRONMENT < string > yes Environment in which this application is being run.
ROKWIRE_CORE_PORT < int > no Port to be used by this application. Defaults to 80.
ROKWIRE_CORE_HOST < string > yes URL where this application is being hosted.
ROKWIRE_CORE_MONGO_AUTH <mongodb://USER:PASSWORD@HOST:PORT/DATABASE NAME> yes MongoDB authentication string. The user must have read/write privileges.
ROKWIRE_CORE_MONGO_DATABASE < string > yes MongoDB database name.
ROKWIRE_CORE_MONGO_TIMEOUT < int > no Timeout for connection attempts to MongoDB in milliseconds. Defaults to 500.
ROKWIRE_CORE_AUTH_TWILIO_ACCOUNT_SID < string > no Twilio Account SID. Twilio phone authentication will not work without this variable.
ROKWIRE_CORE_AUTH_TWILIO_TOKEN < string > no Secret token needed to access Twilio APIs. Twilio phone authentication will not work without this variable.
ROKWIRE_CORE_AUTH_TWILIO_SERVICE_SID < string > no Twilio Service SID for the phone verification service. Twilio phone authentication will not work without this variable.
ROKWIRE_CORE_SMTP_HOST < string > no Host address of the SMTP server. Email verification will not work without this variable.
ROKWIRE_CORE_SMTP_PORT < int > no Port used to send emails through the SMTP server. Email verification will not work without this variable.
ROKWIRE_CORE_SMTP_USER < string > no Username for the user on the SMTP server. Email verification will not work without this variable.
ROKWIRE_CORE_SMTP_PASSWORD < string > no Password for the user on the SMTP server. Email verification will not work without this variable.
ROKWIRE_CORE_SMTP_EMAIL_FROM < string > no "From" email address to be used when sending emails. Email verification will not work without this variable.
ROKWIRE_CORE_AUTH_PRIV_KEY < string > yes PEM encoded private key for auth service keypair. Not required if ROKWIRE_CORE_AUTH_PRIV_KEY_PATH is set.
ROKWIRE_CORE_AUTH_PRIV_KEY_PATH < string > yes Path to file containing PEM encoded private key for auth service keypair. Not required if ROKWIRE_CORE_AUTH_PRIV_KEY is set.
ROKWIRE_CORE_MIN_TOKEN_EXP < int > no Minimum duration of access tokens to be allowed in minutes. Defaults to 5.
ROKWIRE_CORE_MAX_TOKEN_EXP < int > no Maximum duration of access tokens to be allowed in minutes. Defaults to 60.
ROKWIRE_CORE_MIGRATE_PROFILES < bool > no Boolean value indicating whether profiles should be migrated from the Profile Building Block. Defaults to false.
ROKWIRE_CORE_PROFILE_BB_HOST < string > no Profile Building Block host URL
ROKWIRE_CORE_PROFILE_BB_API_KEY < string > no Internal API key for accessing the Profile Building Block
ROKWIRE_CORE_SYSTEM_APP_TYPE_IDENTIFIER < string > yes Identifier for system admin application type. This should be the application or bundle identifier for Android/iOS respectively. Only required for first run.
ROKWIRE_CORE_SYSTEM_APP_TYPE_NAME < string > yes Name for system admin application type. Only required for first run.
ROKWIRE_CORE_SYSTEM_API_KEY < string > yes API key for system admin application. Only required for first run.
ROKWIRE_CORE_SYSTEM_ACCOUNT_EMAIL < string > yes Email address for initial system admin account. Only required for first run.
ROKWIRE_CORE_SYSTEM_ACCOUNT_PASSWORD < string > yes Password for initial system admin account. Only required for first run.
ROKWIRE_CORE_BASE_SERVER_URL < string > false URL of base server which overrides all of the servers listed in the docs.
ROKWIRE_CORE_PRODUCTION_SERVER_URL < string > false URL of base server which overrides the production server listed in the docs.
ROKWIRE_CORE_TEST_SERVER_URL < string > false URL of base server which overrides the test server listed in the docs.
ROKWIRE_CORE_DEVELOPMENT_SERVER_URL < string > false URL of base server which overrides the development server listed in the docs.
USER_AGGREGATE_MINIMUM < int > false value retuned if a service has limited permission and count is less than this value.

Run Application

Run locally without Docker

  1. Clone the repo (outside GOPATH)

  2. Open the terminal and go to the root folder

  3. Make the project

$ make
...
▶ building executable(s)… 1.9.0 2020-08-13T10:00:00+0300
  1. Set environment variables

  2. Run the executable

$ ./bin/health

Run locally as Docker container

  1. Clone the repo (outside GOPATH)

  2. Open the terminal and go to the root folder

  3. Create Docker image

docker build -t core .
  1. Create env.list file containing the environment variables

  2. Run as Docker container

docker run --env-file env.list -p 80:80 core

Tools

Run tests
$ make tests
Run code coverage tests
$ make cover
Run golint
$ make lint
Run gofmt to check formatting on all source files
$ make checkfmt
Run gofmt to fix formatting on all source files
$ make fixfmt
Cleanup everything
$ make clean
Run help
$ make help
Generate Swagger docs

To run this command, you will need to install swagger-cli

$ make oapi-gen-docs
Generate models from Swagger docs

To run this command, you will need to install oapi-codegen

$ make make oapi-gen-types

Test Application APIs

Verify the service is running as calling the get version API.

Call get version API

curl -X GET -i http://localhost/core/version

Response

0.0.0

Contributing

If you would like to contribute to this project, please be sure to read the Contributing Guidelines, Code of Conduct, and Conventions before beginning.

Secret Detection

This repository is configured with a pre-commit hook that runs Yelp's Detect Secrets. If you intend to contribute directly to this repository, you must install pre-commit on your local machine to ensure that no secrets are pushed accidentally.

# Install software 
$ git pull  # Pull in pre-commit configuration & baseline 
$ pip install pre-commit 
$ pre-commit install

Staying up to date

Follow the steps below to stay up to date with the associated version of this service. Note that the steps for each version are cumulative, so if you are attempting update applications that were using a version of this service which is now multiple versions out of date, be sure to make the changes described for each version between the version your application was using and the latest.

[Unrealeased]

Breaking changes

model
  • Any Permission may now be added to or removed from an Account, AppOrgRole, or AppOrgGroup if at least one of its assigner permissions is satisfied by the assigning user. Any application that computes whether a given user will be allowed to modify permissions in an Account, AppOrgRole or AppOrgGroup before sending the request to do so will need to be updated for accuracy.