Skip to content
This repository has been archived by the owner on Dec 11, 2023. It is now read-only.

Latest commit

 

History

History
174 lines (131 loc) · 5.97 KB

README.md

File metadata and controls

174 lines (131 loc) · 5.97 KB

Analog Studios - API Project

Backend API component for Analog Studios 2.0 Redesign

Install

This project uses Vagrant for local development. To use it please install

  1. Vagrant >= 1.7.4
  2. VirtualBox >= 5.x and latest available version guest additions (should get prompted during VB installation)
  3. Add this entry to your hosts file
127.0.0.1       local.analogstudios.thegreenhouse.io
  1. Add the EditorConfig plugin to your IDE

Project Layout

  • ini/ - tracked and un-tracked environment based configuration files
  • bin/ - executable scripts for Jenkins, Vagrant, etc
  • sql/ - sql backups
  • src/ - application code
  • src/resources/ - available collections to map to endpoints
  • src/routes/ - map of endpoints to resources
  • src/services/ - helper / utitlity functions, classes not mapped to collectionsgit
  • tests/ - unit and integration tests organized to match the src direectory

Vagrant

  1. Start Vagrant vagrant up
  2. ssh into the box vagrant ssh
  3. move to the project root cd /vagrant

Local Development

For the most part, you will just need to write code and then write tests for it and see if they pass or fail. This can be done with

$ phing develop`

For testing any of the build targets and running in Vagrant, append this to all commands

-D buildDir=/home/vagrant/build && cp src/.htaccess /home/vagrant/build/

Build

  1. standard production build (WITH linting, docs, tests)
$ phing build
  1. "expedited" build (NO linting, docs, tests)
$ phing build:exp

You can test from the Vagrant VM using cURL curl localhost/api/events

Or the browser / POSTman against your host machine localhost:4567/api/events

note: Install POSTman and make an account and contact me to get access to all the APIs for the project.

API Documenation

To generate API documentation run $ phing clean $ phing docs

and open {path/to/repo/in/your/filesystem}/reports/docs/index.html in your browser

Testing

PHPunit is used for unit testing phing test

To see code coverage, open {path/to/repo/in/your/filesystem}/reports/coverage_result/index.html in your browser

Dependency Management

Composer is used for managing / install 3rd party dependencies for the project. It also creates an autoloader.

To install all the dependencies from package.json $ composer install

To install a new dependency `$ composer require {package-name}

To upgrade an existing dependency `$ composer require {package-name}

Deployment

Environment Configuration

The application expects the following files to be deployed to the webroot

  • config.ini
  • as-api.phar
  • controller.php

In some form or another, the environment should have some sort of rewriting / proxying of requests for the API to pass to controller.php. This is a common feature of webservers like Apache and Nginix. A basic example for Apache would be

<Directory /var/www/html>               
    Options Indexes FollowSymLinks MultiViews
    AllowOverride All
    Order allow,deny
    allow from all
   
    RewriteEngine On
                  
    RewriteCond %{HTTP:Authorization} .+
    RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
    RewriteCond $1 ^api\/
    RewriteRule ^(.*) controller.php [L,PT]
   
    FallbackResource /index.html
</Directory>

App Config (ini)

config-bootstrap.ini contains the initial configuration needed for the application, and should be deployed in the webroot, configured accordingly, and renamed to config.ini. (This is done automatically when developing locally)

  • env_config_ini_path - path to env config for application.

It is highly recommended that the config-{env}.ini file be located outside the webroot

Env Config (ini)

config-env.ini path should be configured in config-bootrap.ini (see above). When deployed, the file should be renamed to config-env.ini (This is done automatically when developing locally)

Note: The actual environment specific ini files are not tracked in version control

  • db.host - the hostname for the database (i.e. localhost, 127.0.0.1)
  • db.name - name of the database for the application
  • db.user - the user to connect to the DB as
  • db.password - the password for the db user
  • runtime.displayErrors - display runtime errors or not (i.e. on or off)
  • session.domain - the domain the app is running under (i.e. www.analogstudios.net)

note: SENSITIVE CREDENTIALS SHOULD NOT BE COMMITTED TO THE REPO! DB BACKUPS ARE ONLY FOR LOCAL TESTING, RDS SHOULD PRESERVE ALL BACKUPS*

Database

The application database is hosted in AWS RDS. All the relevant sql backup and patch files are included in the src/sql directory. For each release, an incremented sql file is expected such that it can be run on the prod database for when a schema change is made. When a release happens, the current production database should be backed (primary to keep the Vagrant created test databases current with production).

note: SENSITIVE CREDENTIALS SHOULD NOT BE COMMITTED TO THE REPO! DB BACKUPS ARE ONLY FOR LOCAL TESTING, RDS SHOULD PRESERVE ALL BACKUPS*

Creating a new resource / endpoint (/events, /artists, etc )

  1. Copy paste an existing resource (like Artists)
  2. Update $name, $tableName, $requiredParams, $updateParams, $optionalParams
  3. Update method params (getFoo, getFooById, etc)
  4. Add new case in src/resources/ResfulResourceBuilder
  5. Copy paste an existing test (like Artists in tests/resources) and update for all CRUD operations
  6. Test each CRUD operation one at a time using phing test
  7. Add resource name to $resources array
  8. Add a "route" case in controller.php
  9. Create a route file in /routes, to match your resource name and route case
  10. Test all endpoints in POSTman