generator-sails-rest-api
data:image/s3,"s3://crabby-images/84f82/84f82c765f46668a260a04f5f71494dc76704b7c" alt="License"
Stability: 2 - Unstable
The project is in the process of settling, but has not yet had sufficient real-world testing to be considered stable.
Backwards-compatibility will be maintained if reasonable.
Yeoman generator that provides already configured and optimized Sails REST API with bundle of predefined features.
Build Status
Version | Build Status | Coverage Status |
---|
Edge (dev) | data:image/s3,"s3://crabby-images/aac5f/aac5f9197f2a4dd7a5ec2a0c639584101f6932c5" alt="Edge Version" | data:image/s3,"s3://crabby-images/49f30/49f308c45e2cbf5645981230e33fd995aae10fae" alt="Edge Version" |
Stable (master) | data:image/s3,"s3://crabby-images/eea10/eea109291076e018804a5ea8c6bb6165be6a7a73" alt="Stable Version" | data:image/s3,"s3://crabby-images/be5eb/be5eb2a61d77771d3ef9454ca05b0fe095461309" alt="Stable Version" |
Features
- Disabled hooks by default: cors, csrf, grunt, i18n, pubsub, session, views;
- Overrides default
blueprints
which simplify CRUD operation in REST API; - Implemented
AuthController
, PingController
and UserController
; - Already declared
User
model with most used fields; - Implemented 2 policies:
isAllowed
which checks if request is going from our applications, and isAuthenticated
which inject user in req
via JSON Web Token; - Custom responses which respond with
code
(Status Code), message
(Status Message) and data
(Response Data) fields; - Bundle of ready-2-use services like
CipherService
, PusherService
(Push Notifications), SmsService
and so on... You can check table with detailed list of implemented services below; - Integrated Passport with Facebook, Twitter, VKontakte, GitHub, Instagram, Google Plus and other social networks, JWT and Local authorization strategies;
- All configuration files cleaned up and optimized for REST API;
- Winston logger with logging to console and DailyRotateFile is enabled by default;
- Bunch of Sails adapters is already declared in
connections
configuration file so you can easily swap between them;
Getting Started
Start using generator is very simple.
First of all, you need install yeoman and generator-sails-rest-api:
npm install -g yo generator-sails-rest-api
Then create project directory and initiate the generator under the project directory:
mkdir my-project
cd my-project
yo sails-rest-api
You will be prompted for questions. Answer to those questions that generator is asks and you will get configured Sails project.
After scaffolding the project you can use this project as before. Just run the app.js
file and all.
node app.js
Congratulations, you just have setup your first Sails REST API :+1:
How to use project code?
TODO: Fill with information. But you can read more at our wiki page
Bundled Sails services
Service Name | Implemented providers |
---|
CipherService | bcrypt, JWT |
MailerService | Mandrill |
PaymentService | Stripe |
PusherService | Apple Push Notifications, Google Cloud Messaging |
SmsService | Twilio |
SocialService | Facebook |
StorageService | Amazon S3, Google Cloud |
How can I get latest dev version of generator?
Right now this generator is extremely under development, so each day our dev
branch has new updates and fixes.
If you want get the latest updates, you should do this:
git clone https://github.com/ghaiklor/generator-sails-rest-api.git
cd generator-sails-rest-api
npm link
After that our git repository will be linked to your global npm module and you can use it as described above.
If any updates will come you can just pull the last changes and call generator again:
cd generator-sails-rest-api
git pull
yo sails-rest-api
License
Copyright © 2015 Eugene Obrezkov
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see http://www.gnu.org/licenses/.