Wraps all main Goggles' API endpoints in a stand-alone application.
The endpoints allow an authorized account to manage most DB entities as they are defined in the DB structure, returning usually a composed result that includes all first-level associations and look-up entities as well.
- Official Framework Wiki 🔗 (v. 7+)
- Ruby 3.1.4
- Rails 6.0.6.1+
- MariaDb 10.6.12+ or any other MySql equivalent version
The official API documentation is in API Blueprint format and stored directly on this repository, under /blueprint
.
The main index is api_main.apib
stored in the project root while all its sibling pages are inside the aforementioned /blueprint
folder.
To easily browse the documents while working on them, we recommend the usage of Visual Studio Code with the API Blueprint Viewer extension installed, since generating a new single static document each time is definitely cumbersome.
IDE:
-
VisualStudio Code with at least the following extensions:
- API Blueprint syntax highlighter
- API Blueprint Viewer
- any JSON prettyfier
html2haml
gem together with its VSCode extension- any other relevant & VSCode-suggested extension (Ruby, Rails, MariaDB/MySQL & Docker for once)
-
Hercule, for managing the API document split among multiple files. Install it globally with:
$> sudo npm install -g hercule
Using Atom as favorite IDE may work too although, last time we checked, the available API Blueprint plugin was showing more issues than the one in VSCode.
- GogglesDb base engine, core 7+
- JWT for session handling
- Grape gem for API definition
You will need to install the GogglesDb gem disabling the download of the embedded test dump with:
$> GIT_LFS_SKIP_SMUDGE=1 bundle install
Use the same parameter when updating the gem with bundle update goggles_db
or just run the dedicated script:
$> ./update_engine.sh
Obtain a valid anonymized test DB dump image by cloning goggles_db
repo on localhost and run from the its project root:
$> cd goggles_db
$> RAILS_ENV=test rails app:db:rebuild
Check out Database setup on GogglesDb project's README for more info.
All framework app projects (except for the mountable engines) handle multiple configurations for execution, development & deployment.
You can use each project of the suite:
- as full-blown local installations (by cloning the source repos on localhost)
- as a single service composed from individual containers (either by rebuilding the individual containers from scratch or by pulling the images from their DockerHub repository)
- in any other mixed way, be it the application running on localhost while accessing the DB inside a container or vice-versa.
Check out also the WiKi about repository credentials: management and creation.
You'll need a MariaDb running server & client w/ dev
libraries (tested & recommended); alternatively, an up-to-date MySQL installation.
Clone the repository on localhost and use it as you would with a normal Rails application.
In order to start development, you'll need to:
- create new API credentials or obtain a valid
config/master.key
for the defaultcredentials
file (see Wiki about this); - customize
config/database.yml.example
according to your local MySQL installation and save it asconfig/database.yml
; - customize
.env.example
(as above) and save it as.env
in case you want to build the Docker containers; - obtain a a valid compressed development or test seed (
.sql.bz2
) stored underdb/dump
(see Database setup).
For usage as a composed Docker container service you won't need an actual installation of MySQL or MariaDB at all, although a client mysql
installation is recommended in case you want to run SQL commands into the DB container from the localhost shell.
If you're using the orchestrated container service, just choose a random password for the database in the .env
file before building the containers and follow the WiKi How-To:
Refer to: Setup as individual Docker containers
The Dockerfile
s & docker-compose
YML files work with some assumptions throughout the framework about published ports between containers and the host which is running Docker.
For instance, by changing just the current Database port in your customized database.yml
you could switch from a typical localhost MySQL install (port 3306 running on socket) to a containerized MySQL Database on the different port published on the service (port 33060 using IP protocol).
Service | Default internal port | Default published port |
---|---|---|
"inside" containers | "outside" service | |
Database (MariaDB/MySQL) | localhost:3306 |
33060 |
Web app | localhost:3000 |
8081 |
The current staging
environment configuration is an example of the app running locally while connecting to the goggles-db
container service on localhost:33060
. (See the dedicated paragraph below.)
The API service stores an API Audit log inside log/api_audit.log
.
The Logger instance will split it and keep the latest 10 files of 1 MB each.
At the same time, each API call will update a dedicated entry in the api_daily_uses
table, which can be used to compute crude usage stats on a daily basis.
For local testing, just keep your friend Guard running in the background, in a dedicated console:
$> guard
If you want to run the full test suite, just hit enter on the Guard console. Refer to the official Guard docs for more info.
As of Rails 6.0.3, most probably there are some issues with the combined usage of Guard & Spring when used together with the new memory management modes in Rails during the Brakeman checks. These prevent the brakeman
plugin for Guard to actually notice changes in the source code:if you create a vulnerability and subsequently fix it, the checks get re-run by Guard but the result doesn't change.
Maybe it could be just a combined mis-configuration we haven't investigated thoroughly but, in any case, although the Guard plugin for Brakeman runs correctly at start, it's always better to re-run the brakeman
checks before pushing the changes to the repository with:
$> brakeman -c .brakeman.cfg
If you don't have a local test database setup, check out "Database setup".
Make sure you commit & push any changes only when the test suite is 💚.
Although not optimized for testing, the dev
composed service can be used to run RSpec, Rubocop or anything else, including Guard too.
Refer to the "GogglesAPI: Docker usage" guide for more detailed instructions.
Run the composed container in detached mode, then connect to its internal shell and run the tests:
$> docker-compose -f docker-compose.dev.yml up -d
$> docker-compose -f docker-compose.dev.yml exec app sh
/app # RAILS_ENV=test bundle exec rspec
/app # RAILS_ENV=test bundle exec rubocop
/app # RAILS_ENV=test bundle exec brakeman -q
/app # RAILS_ENV=test bundle exec guard
Inside the container, remember to:
- always prefix the usual commands with
bundle exec
(as inbundle exec rails console
, ...) to reach the correct bundle (stored in/usr/local/bundle
); - override the default RAILS_ENV
development
for anything test-related.
When you push a commit to the master
branch, the build system will re-test everything you allegedly have already checked locally using Guard as described above.
The project uses a full CI pipeline setup on Semaphore 2.0 (currently for the master
branch only) that will promote a successful build into the Docker latest
production-only image on DockerHub.
All other tagged Docker images will be auto-built by DockerHub itself, as soon as any specific branch has been manually tagged as a release from the GitHub UI. (Using GitHub release tags that respect semantic versioning, with format MAJOR
.MINOR
.BUILD
)
Given this, avoid cluttering the build queue with tiny commits (unless these are hotfixes) and with something that hasn't been greenlit by a local run of the whole test suite: it's adamant that you don't push failing builds whenever possible.
Basically, remember to:
- login to docker from the console with
docker login
whenever you're using Docker for testing or development (in order to avoid pull/push threshold caps); - always develop with a running
guard
in background; - when you're ready to push, do a full test suite run (just to be sure);
- run also an additional Brakeman scan before the push as suggested above.
Refer to GogglesDb setup.
You'll need a proper DB for both the test suite and the local development.
Assuming we want the test
environment DB up and running, you can either have:
-
Make sure you have a running MariaDB server & client installation.
-
Given you have a valid
db/dump/test.sql.bz2
(the dump must be un-namespaced to be copied or renamed from any other environment - as those created bydb:dump
typically are), use the dedicated rake tasks:
$> bin/rails db:rebuild from=test to=test
$> RAILS_ENV=test bin/rails db:migrate
(It will take some time, depending of the dump size: sit back and relax.)
Refer to "Getting started: setup and usage as a composed Docker service" or to "DB container setup & usage" for in-depth details.
Staging will use a custom copy of the production
environment together with the database running on the production Docker image (tag: latest
) of the composed service (DockerHub: steveoro/goggles-api:latest
), minus the SSL enforcing (so that we can test that easily on localhost).
To recreate or restore a usable database with testing seeds, assuming:
- you have a valid
test.sql.bz2
dump file stored underdb/dumps
; - the DB container
goggles-db
has been already built and already running;
Execute the dedicated task:
$> RAILS_ENV=staging rails db:rebuild from=test to=staging
Run the server on localhost with:
$> rails s -p 8081 -e staging
...Or the console with:
$> rails c -e staging
🚧 TODO 🚧
- Clone the project.
- Make a new custom branch for your changes, naming the branch accordingly (i.e. use prefixes like:
feature-
,fix-
,upgrade-
, ...). - When you think you're done, make sure you type
guard
(+Enter
) and wait for the whole spec suite to end. - Make sure your branch is locally green (:green_heart:) before submitting the pull request.
- Await the PR's review by the maintainers.
The application is available as open source under the terms of the LGPL-3.0 License.
Check out the "sponsor" button at the top of the page.