Security News
cURL Project and Go Security Teams Reject CVSS as Broken
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
API-driven framework for building realtime apps, using MVC conventions (based on Express and Socket.io)
Sails.js is a web framework that makes it easy to build custom, enterprise-grade Node.js apps. It is designed to resemble the MVC architecture from frameworks like Ruby on Rails, but with support for the more modern, data-oriented style of web app & API development. It's especially good for building realtime features like chat.
Since version 1.0, Sails supports await
out of the box. This replaces nested callbacks (and the commensurate error handling) with simple, familiar usage:
var orgs = await Organization.find();
# Get the latest stable release of Sails
$ npm install sails -g
Upgrading from an earlier version of Sails?
Available as of Node >=v7.9 and Sails >=v1.0, ES8's async/await enables dramatic improvements to the way developers build Node.js / Sails apps. It allows server-side JavaScript code to be written with the
await
keyword, instead of lower-level (and more fragile) flow control mechanisms like nested callbacks and promise chains. It lets developers breathe easier by removing the burden of painstaking, manual error handling after every database query. And best of all, it means the end of "callback hell": the most common source of bugs and stability issues in real world Node.js / Sails applications.If ES8 isn't for you, don't worry-- Node callbacks and promise chaining are still fully supported. But for most teams, the transition to
await
results in sizable gains in productivity, with fewer lines of code.Upgrade guides for all major releases since 2013 are available on the Sails website under Upgrading.
Create a new app:
# Create the app
sails new my-app
Lift sails:
# cd into the new folder
cd my-app
# fire up the server
sails lift
For the most up-to-date introduction to Sails, get started here.
Sails is built on Node.js, Express, and Socket.io.
Sails actions are compatible with Connect middleware, so in most cases, you can paste code into Sails from an existing Express project and everything will work-- plus you'll be able to use WebSockets to talk to your API, and vice versa.
The ORM, Waterline, has a well-defined adapter system for supporting all kinds of datastores. Officially supported databases include MySQL, PostgreSQL, MongoDB, Redis, and local disk / memory. Community adapters exist for CouchDB, neDB, TingoDB, SQLite, Oracle, MSSQL, DB2, ElasticSearch, Riak, neo4j, OrientDB, Amazon RDS, DynamoDB, Azure Tables, RethinkDB and Solr; for various 3rd-party REST APIs like Quickbooks, Yelp, and Twitter, including a configurable generic REST API adapter; plus some eclectic projects.
For the latest core adapters and notable community adapters, see Available Adapters.
Need help or have a question?
Please read the submission guidelines and code of conduct before opening a new issue. Click here to search/post issues in this repository.
There are many different ways you can contribute to Sails:
Please carefully read our contribution guide and check the build status for the relevant branch before submitting a pull request with code changes.
Sails is actively maintained with the help of many amazing contributors. Our core team consists of:
Mike McNeil | Cody Stoltman | Scott Gress | Irl Nathan | Rachael Shaw |
Our company designs/builds Node.js websites and apps for startups and enterprise customers. After building a few applications and taking them into production, we realized that the Node.js development landscape was very much still the Wild West. Over time, after trying lots of different methodologies, we decided to crystallize all of our best practices into this framework. Six years later, Sails is now one of the most widely-used web application frameworks in the world. I hope it saves you some time! :)
MIT License Copyright © 2012-present, Mike McNeil
Sails is built around so many great open-source technologies that it would never have crossed our minds to keep it proprietary. We owe huge gratitude and props to Ryan Dahl (@ry), TJ Holowaychuk (@tj), Doug Wilson (@dougwilson) and Guillermo Rauch (@rauchg) for the work they've done, as well as the stewards of all the other open-source modules we use. Sails could never have been developed without your tremendous contributions to the JavaScript community.
1.1.0
As always, we owe a debt of gratitude to our contributors-- we mentioned you below next to the features/enhancements/fixes you contributed to. (Apologies to anyone we missed, there was a lot in this release! Let us know and we'll add you to the list.)
We especially want to thank those contributors who helped out with the documentation:
- Rachael Shaw
- Mike McNeil
- Ali Norouzi
- Ronny Medina
- Alex Schwarz
- Xavier Spriet
- Ian Harris
- Vladyslav Piskunov
- Michael Frederick
- Mark Strelecky
- Freddy
- pavan
- Scott Reed
- Mario Colque
- Okoli Lemuel
- ultimate-tester
- @snidell
- Pika
- AYEDOUN Fiacre
- Tim Wisniewski
- Tom Saleeba
- s-slavchev
- Daniel Harvey
- Julien Le Coupanec
- floriancummings
- Bernardo Gomes
- Eli Peters
- Dennis Cheung
- Minh Tri Nguyen
Finally, big thanks to Dennis Cheung who did the painstaking work of compiling this changelog!
~mike
.updateOne()
, .destroyOne()
, and .archiveOne()
exits
argument may now be excluded from your fn
function in all helpers, actions2 definitions, and shell scripts..stream()
, .transaction()
, and .leaseConnection()
. Functions provided as procedural parameters (i.e. during
and iteratees) no longer expect a callback to be invoked, as long as you omit their 2nd callabck argument from the function signature.config/bootstrap.js
) and the initialize
function of hooks no longer expect a callback to be invoked, as long as the callback argument is excluded from the function signature..timeout()
and .retry()
.create
method to datastore fixture, and test "no validation errors" case. (Scott Gress)update
(Scott Gress)_.each()
with _.forIn()
to enable ORM to accept attributes named 'length'. (Daniel Harvey)this.modal
, since there can only be one modal on the page at a time anywaya:not(.btn)
styles from homepage, because those are set elsewhere nowtmp
in www tests to attempt to fix Appveyor issues (Scott Gress)tmp
in remaining www test to try and address random Appveyor failures (Scott Gress)customize
optionlower
(Xavier Spriet)add
and remove
encodeURIComponent
instead of encoreURI
for url-friendly
style.exits
against raw instead of built machine as it seems as though the built machine doesn’t expose the exits (Yuki von Kanel).switch(...)
where needed (Yuki von Kanel)FAQs
API-driven framework for building realtime apps, using MVC conventions (based on Express and Socket.io)
The npm package sails receives a total of 36,771 weekly downloads. As such, sails popularity was classified as popular.
We found that sails demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.