Skip to content

Latest commit

 

History

History
109 lines (66 loc) · 7.34 KB

README.md

File metadata and controls

109 lines (66 loc) · 7.34 KB

YAPI (Yuiti's API) PHP

A simple base API project based on Slim and Doctrine. This is very basic, but provides some authentication and token validation.

Use it to bootstrap simple API projects! ;)


How To

Important (Before you start editing everything here)

On its first run, you'll see that a __SALT file will be generated in the data folder, inside project root. This file contains a unique, and random, security key that's used for signing the JSON Web Token and it's also the security salt for password hashing.

DO NOT DELETE THIS FILE, since deleting it in production environment means losing ALL user passwords and invalidating of ALL existing access tokens. For safety reasons, TWO backup copies are created, but BE CAREFUL when tinkering with it, ok? 😉

index.php

When you first open this file, you'll notice that it only requires the Api.php from src\api, runs the Api class and uses its getApp() method to retrieve the \Slim\App instance and run() it.

Well, if you're thinking "but, is that everything?", then YES! That's everything that it needs to do for the purpose of this project. For real, no kidding! (Sorry for this one, next files will be a bit more serious)

src\api\Api.php

This is probably the file you'll tinker with first when using this project. It basically holds a class that:

  • Loads the environment variables from the .env file in the project's source;
    • Well, when you clone this project you'll see that this .env file doesn't exist! That's because it's YOUR job to create it, based on the .env.example file, and update every information in it 😉;
      • This is because .env contains sensitive data about your application, like the database authentication information, and it's safer to put these information on a not-so-easily shared way when working with public projects;
  • Fires an instance of \Slim\Container and defines some of the application dependencies in it;
  • Fires an instance of \Slim\App and the RouteHandler, which receives the app instance in its constructor;
  • Defines the TrailingSlash and authentication middlewares;

The places you might tinker with, in this file are probably the contents in the dependencies() and the authentication() methods, mostly because of some different dependencies, translating error messages or just changing the way the app uses authentication middleware.

Outside of these methods, there's not much to tinker in this file, which leaves us to the next most probable file to tinker with...

src\api\RouteHandler.php

The RouteHandler receives a reference to an instance of \Slim\App in its constructor and then applies the route callbacks using the controller objects in src\api\controllers.

Whenever you build a new controller, it's here that you'll come to properly make use of it.

And that's it for this file! Next...

Controllers

We'll use src\api\controllers\DummyController.php as an example.

Basically, a controller does this:

  • Receives the \Slim\App instance reference from the RouteHandler;
  • Declares the routes this controller it's related to and then applies its internal public methods a callback for each route used;
    • Callbacks use the Slim Framework callback method, you can see more about these callbacks here;
  • Also, the controllers keep a reference to the application and container instances in its $app and $container properties, in case the methods need to use them;

It's really simple to use the controllers this way, but remember to make all methods used in routes public!

Entities

The entities in src\api\models\entity\* follow Doctrine's entity model. So please refer to the Basic Mapping article on Doctrine's documentation for more details on it.

But there are a few things that I do instead of declaring the whole entity here.

You'll see that most (or all) entities extend the BaseEntity class located in src\api\core\BaseEntity.php. The Base Entity is an entity without the @Entity and @Table annotations, but it does declare some annotated properties and getter/setter methods.

While you CAN declare this inheritable entity as an @Entity with a @Table, we don't do this so it won't cause problems further when we use Doctrine's QueryBuilder to select entities from the database, as these annotations will cause a bit of a mess in select operations with any extended child by adding some unknown aliases.

The properties the BaseEntity define are:

  • id: an integer that serves as primary key;
  • uuid: a string, that holds a UUID for the entity, using the UUID v4 generator;
  • created_at/updated_at: creation and updated dates for this entity;
  • deleted: a boolean that serves a a soft delete flag, since I don't like to delete things so easily;

The uuid, created_at and updated_at are created by methods that have @PrePersist and @PreUpdate annotations. Because of this, ALL classes that extend the BaseEntity must have the @HasLifecycleCallbacks annotation.

Other Folders and Files of Interest

The files and instruction above are most of the things you'll have to tinker with when using this project. But there are some other things that you can customize or need to be careful with too, which are:

  • src\data\: initialized automatically by the project, this folder stores the security salt files, after initialized, so DO NOT delete it if you're in production environment! It also stores the SQLite database, if using the SQLite driver;
  • src\bootstrap\: this folder contains the base group, role and permissions JSON data to be initialized by the bootstrap script together with the root user;
  • src\api\config\constants.php: this file is autoloaded by autoload.php, and it declares constants used globally;
  • src\api\core\BaseEntity.php: the base entity, that declares some basic properties for entities which can be inherited;
  • src\api\core\ClientInformation.php: a simple, plain PHP object that fetches some information from the client requesting information;
  • src\api\core\Mappable.php: multiple classe in the project extend this one, hence it's one of the most important files here. It basically sets and implements methods that allow an instance of a class to be mapped into an associative array with its public/protected properties as keys, and also allows easy/lazy JSON serialization with json_encode;
  • src\api\core\ResponseError.php: a simple template for error responses for the API;
  • src\api\core\ResponseTemplate.php: a simple template for JSON Responses used by the API;
  • src\api\core\Salt.php: handles security salt generation and retrieving;
  • src\api\core\Utilities.php: contains some public static methods used throughout the API;

And that's basically it! 😉


Authors

See AUTHORS.md for more information.


License

This project is licensed under the MIT License. See LICENSE.md for more details on the subjects of the license.


©2018-2020 Fabio Y. Goto