Skip to content

Latest commit

 

History

History
133 lines (96 loc) · 3.62 KB

README.md

File metadata and controls

133 lines (96 loc) · 3.62 KB

GroupHub API

REST API based on Symfony and FOSRest bundle.

Description of what this API is can be found at: https://wiki.surfnet.nl/display/P3GFeI2015/3.+Management+laag

Host machine requirements

  • Virtualbox
  • Vagrant
  • Ansible

Vagrant plugins

Make sure you have the following vagrant plugins installed.

vagrant-hostsupdater >=(0.0.11)
vagrant-share >=(1.1.4, system)
vagrant-vbguest >=(0.10.1)

Installation

  • Run vagrant up in order to get the vagrant machine running
  • Run composer install in order to load/install all required dependencies.

The composer install command will ask you about your database credentials. Make sure you have an empty MySQL database and MySQL user/pass available. The command will write the app/config/parameters.yml that is required by the Symfony framework.

Getting started

After starting and provisioning your vagrant box you can go to: http://dev.api.grouphub.org/app_dev.php

API Documentation

Or when you have the vagrant box running you can go to http://dev.api.grouphub.org/app_dev.php/api/doc to see the runtime documentation version.

Deployment

Requirements

  • sshd (with a configured 'deployment' user)
  • apache2 (vhost see below)
  • mysql (with a configured user and database)
  • git
  • acl
  • php
    • php5-intl
    • php5-curl
    • php5-apcu

Consider setting opcache.validate_timestamps to 0 in php.ini for a lot of free performance!

Also make sure there is a directory /project/dir/ available which is writable by the deployment user.

If you want to deploy the app you will need capistrano-symfony:

gem install capistrano-symfony --pre-release

Vhost

Minimum requirements:

<VirtualHost *:80>
    ServerName api.grouphub.org
    
    DocumentRoot /project/dir/current/web
    
    <Directory /project/dir/current/web>
        Options FollowSymLinks
        AllowOverride All
        Order Allow,Deny
        Allow from All
    </Directory>
</VirtualHost>

Usage of HTTPS is highly recommended. Also consider the API to be only accessible by accepted IP addresses.

Process

To do an actual deployment, make sure a stage is available in app/config/deployment/stages/. Then run

cap [stage-name] deploy

This script will ask the branch/tag of the software to deploy. The default will probably be sufficient in most cases.

The first time the script will most likely fail because the configuration is invalid, fix this manually as described below, then run the script again.

Configuration

Configuration can be found in app/config/parameters.yml:

parameters:
    # Database connection data and credentials
    database_driver:   pdo_mysql
    database_host:     127.0.0.1
    database_port:     ~
    database_name:     grouphub
    database_user:     grouphub
    database_password: password

    # Mailer settings
    mailer_transport: smtp
    mailer_host:      127.0.0.1
    mailer_user:      ~
    mailer_password:  ~

    # A random string for security purposes 
    secret: ThisTokenIsNotSoSecretChangeIt

    # The password required to access this API
    password_user: ~

    # Data of the 'admin' user which will be made a member of the root admin group
    admin_uid: admin
    admin_dn:  cn=Admin Admin,ou=Users,ou=SURFuni,dc=surfuni,dc=org

    # The URL of this API, used to clear the cache after a new deployment
    url: http://api.grouphub.surfuni.org

Database setup

The very first time the site is deployed some initial data needs to be imported, this can be done as follows (on the remote server):

app/console doctrine:database:create
app/console doctrine:schema:create
app/console doctrine:fixtures:load