Skip to content

crankedapps/slim-rest-boilerplate

Repository files navigation

slim-rest-boilerplate

A PHP-based user-authenticated REST API boilerplate by John Endicott, using:

Installation

  • git clone https://github.com/crankedapps/slim-rest-boilerplate.git clone git repo
  • cd slim-rest-boilerplate change working directory to root project folder
  • composer install install dependencies
  • Edit ./phinx.yml and ./app/Config/Config.php with MySQL configurations
  • ./vendor/bin/phinx migrate run initial database migration

Run

  • cd public change working directory to public folder and run localhost -S localhost:8000 via command line
  • or you can use Apache, set virtual host to public folder

Tests

Execute unit tests via PHPUnit by running ./vendor/bin/phpunit ./tests/. You can debug tests via XDebug by running ./phpunit-debug ./tests/ (use Git Bash if on Windows). This boilerplate's test suite features 100% code coverage out-of-the-box (see report in ./test/coverage/). To regenerate code coverage HTML report, run ./vendor/bin/phpunit --coverage-html ./tests/coverage/ --whitelist ./app/ ./tests/

API Documentation

HTTP Codes

  • 200 API request successful
  • 400 API request returned an error
  • 401 Unauthorized (access token missing/invalid/expired)
  • 404 API endpoint not found

Authentication

Endpoint Parameters Description
POST /users username string required
password string required
creates a user
POST /users/login username string required
password string required
generates user access token

Endpoints

All RESTful API endpoints below require a Authorization: Bearer xxxx header set on the HTTP request, xxxx is replaced with token generated from the Authentication API above.

Categories

Endpoint Parameters Description
GET /categories n/a lists all categories
GET /categories/{id} n/a gets category data by ID
GET /categories/{id}/todo n/a lists all todo items for a category
POST /categories/ name string required
category integer required
creates a category
PUT /categories/{id} name string optional
category integer optional
updates a category
DELETE /categories/{id} n/a delete category and associated todo items

Todo Items

Endpoint Parameters Description
GET /todo n/a lists all todo items
GET /todo/{id} n/a gets todo item data by ID
POST /todo name string required
category integer required
creates a todo item
PUT /todo/{id} name string optional
category integer optional
updates a todo item
DELETE /todo/{id} n/a deletes a todo item

About

A PHP-based user-authenticated REST API boilerplate built on Slim 3

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages