341 lines
14 KiB
Markdown
341 lines
14 KiB
Markdown
## Concepts
|
|
|
|
### Overview
|
|
|
|
Before we go into all the wonderful concepts that make up LoopBack, let's first
|
|
answer a couple of questions:
|
|
|
|
> What _is_ LoopBack?
|
|
|
|
- A component in the [StrongLoop Suite](http://www.strongloop.com/strongloop-suite).
|
|
- A library of Node.js modules for connecting mobile apps to a variety of data
|
|
sources.
|
|
- A command line tool, `slc lb`, for generating models and entire applications
|
|
with the LoopBack library.
|
|
- A set of SDKs for native and web-based mobile clients.
|
|
|
|
> How does LoopBack work?
|
|
|
|
- LoopBack applications are made up of three components:
|
|
[Models](#models), [Data Sources/Connectors](#data-sources-and-connectors), and the
|
|
[Mobile Clients](#mobile-clients) that consume them.
|
|
|
|
- Any mobile or web app can interact with LoopBack through the Model API that are
|
|
backed by various data sources. The Model API is available
|
|
[locally within Node.js](#model), [remotely over REST](#rest-api), and as native
|
|
mobile SDKs for [iOS, Android, and HTML5](#mobile-clients). Using the API,
|
|
clients can query databases, store data, upload files, send emails, create push
|
|
notifications, register users, and any other behavior provided by data sources.
|
|
|
|
![concepts](assets/loopback-concepts.png "LoopBack Concepts")
|
|
|
|
### Mobile Clients
|
|
|
|
LoopBack provides native Client SDKs to give mobile developers access to remote,
|
|
persistent data in a contextually-relevant way. The transport and marshalling of
|
|
the data is taken care of, and mobile developers can leverage all of their
|
|
existing tools (XCode, Eclipse, et al) to model their data on the client,
|
|
persisting it to the server as needed.
|
|
|
|
To achieve this, LoopBack supports both "Dynamic", schema-less Models and
|
|
"Static", schema-driven Models. (See ["Models"](#models) for more specifics and
|
|
how-tos around Model creation.)
|
|
|
|
Dynamic Models require minimal server code up front (just a name!) to set-up,
|
|
with the format of the data specified _completely_ and _flexibly_ by the client
|
|
application. Well-suited for data that _originates on the client_, mobile
|
|
developers can leverage Dynamic Models to persist data both between sessions and
|
|
between _devices_ while obviating the need for outside engineering support.
|
|
(Let's be honest - how many server programmers do you know that are _excited_
|
|
when you ask them to add a field to some schema on the server? None? That's what
|
|
we thought.)
|
|
|
|
Static Models require more code up front in an extended grammar of JSON we call
|
|
LDL, with the format of the data specified _completely_ in a _structured_ way by
|
|
the server application. Well-suited to both existing data and large, intricate
|
|
datasets, mobile developers can leverage Static Models to provide structure and
|
|
consistency to their data, preventing the multitude of bugs that can result from
|
|
unexpected data in their database. (These pesky bugs _love_ to show up in
|
|
production and ruin everyone's launch day. Stop them before they start!)
|
|
|
|
Use one strategy, or use both. Leverage them to fit your _use case_, rather than
|
|
fitting your use case to some fixed modelling strategy. The choice is yours.
|
|
|
|
### Models
|
|
|
|
> What is a Model?
|
|
|
|
A LoopBack Model consists of the following:
|
|
|
|
- Application data
|
|
- Validation rules
|
|
- Data access capabilities
|
|
- Business logic
|
|
|
|
A mobile client uses the remote API provided by Models to request any
|
|
information needed to display a useful interface to the user or trigger actions
|
|
on the models to interact with backend systems.
|
|
|
|
Let's use a simple example to explain what a model can do for you.
|
|
|
|
#### Defining a model
|
|
|
|
For example, an e-commerce app might have `Product` and `Inventory` Models.
|
|
A mobile client could use the `Product` Model API to search through all of the
|
|
Products in a database. A client could join the `Product` and `Inventory` data to
|
|
determine what products are in stock, or the `Product` Model could provide a
|
|
server-side function (or [remote method](#remote-methods)) that aggregates this
|
|
information.
|
|
|
|
```js
|
|
// Step 1: Create Models
|
|
var Model = require('loopback').Model;
|
|
var Product = Model.extend('product');
|
|
var Inventory = Model.extend('customer');
|
|
```
|
|
|
|
**NOTE:** Models are _schema-less_ by default, but some data sources, such as
|
|
relational databases, _require_ schemas. Additionally, schemas are immensely
|
|
valuable for establishing the common knowledge of business data so that the data
|
|
exchange can be agreed and documented while data coming from mobile clients can
|
|
be validated and/or sanitized . See [Sanitizing and Validating Models](#sanitizing-and-validating-models)
|
|
if your application needs to connect to an RDBMS, for example.
|
|
|
|
#### Attaching to Data Sources
|
|
|
|
Instances of a Model carry application data. But they are not very interesting
|
|
until applications can create, retrieve, update, or delete (CRUD) model instances.
|
|
LoopBack introduces the DataSource concept to provide the data access
|
|
capabilities to models. Attaching a Model to a DataSource gives you access to a
|
|
powerful API mixed into Models by the Connector behind a DataSource. The
|
|
[MongoDB Connector](#), for example, mixes in a `create` method that allows us
|
|
to store a new Product in the database:
|
|
|
|
```js
|
|
// Step 2: Attach Data Sources
|
|
var db = loopback.createDataSource({
|
|
connector: require('loopback-connector-mongodb')
|
|
});
|
|
|
|
// Enables the Model to use the MongoDB API
|
|
Product.attachTo(db);
|
|
|
|
// Create a new product in the database
|
|
Product.create({ name: 'widget', price: 99.99 }, function(err, widget) {
|
|
console.log(widget.id); // The product's id, added by MongoDB
|
|
});
|
|
```
|
|
|
|
Now the models have both data and behaviors. How can the mobile clients benefit
|
|
from them? We need a way to make the models available from mobile clients.
|
|
|
|
#### Exposing to Mobile Clients
|
|
|
|
Models can be exposed to mobile clients using one of the remoting middlewares.
|
|
This example uses the `app.rest` middleware to expose the `Product` Model's API
|
|
over REST.
|
|
|
|
```js
|
|
// Step 3: Create a LoopBack Application
|
|
var app = loopback();
|
|
|
|
// Use the REST remoting middleware
|
|
app.use(loopback.rest());
|
|
|
|
// Expose the `Product` model
|
|
app.model(Product);
|
|
```
|
|
|
|
After this, you'll have the `Product` model with CRUD functions working remotely
|
|
from the mobile clients. Please note the model is schema-less till now and the
|
|
data are not checked.
|
|
|
|
#### Sanitizing and Validating Models
|
|
|
|
A Model can be described in plain json or JavaScript. The description is called
|
|
schema. Once a schema is defined for a Model, it will validate and sanitize data
|
|
before giving it to a Data Source. For example, the `Product` Model has a schema
|
|
that will not change. The example below updates the `Product` Model with a schema
|
|
written in **LoopBack Definition Language**, a well-documented flavor of JSON.
|
|
|
|
```js
|
|
// Step 4: Add a Schema
|
|
var productSchema = {
|
|
"name": { "type": "string", "required": true },
|
|
"price": "number"
|
|
};
|
|
var Product = Model.extend('product', productSchema);
|
|
```
|
|
|
|
On one hand, If a remote client tries to save a product with extra properties
|
|
(e.g. `description`), those properties will be removed before saving the Model.
|
|
On the other hand, the Model will _only_ be saved if the product contains the
|
|
required `name` property.
|
|
|
|
#### More About Models
|
|
|
|
- Check out the Model [REST API](#rest-api).
|
|
- Read the
|
|
[LoopBack Definition Language Guide](http://docs.strongloop.com/loopback-datasource-juggler#loopback-definition-language-guide).
|
|
- Browse the [Node.js Model API](#model).
|
|
- Before you build your own, check out the [bundled Models](#bundled-models).
|
|
- Expose custom behavior to clients using [remote methods](#remote-methods).
|
|
- See how to [define relationships](#relationships) between Models.
|
|
|
|
### Data Sources and Connectors
|
|
|
|
Now you see the power of LoopBack models. A model gets rich set of functions out
|
|
of the box with the contribution from Data Sources and Connectors.
|
|
|
|
The concept of DataSource is introduced to encapsulate business logic to
|
|
exchange data between models and various data sources. Data sources are
|
|
typically databases that provide create, retrieve, update, and delete (CRUD)
|
|
functions. LoopBack also generalize other backend services, such as REST APIs,
|
|
SOAP Web Services, and Storage Services, as data sources.
|
|
|
|
LoopBack allows you to connect to many sources of data and services both in the
|
|
cloud and on-premise in your data center. DataSources are accessed through a
|
|
plugin called a Connector in LoopBack. Plugins are highly customizable and
|
|
extensible. Unlike other mobile backends, LoopBack can leverage your existing
|
|
data and organize them in the form of models.
|
|
|
|
Connectors implement the data exchange logic using database drivers or other
|
|
client APIs. In general, connectors are not used directly by application code.
|
|
The DataSource class provides APIs to configure the underlying connector and
|
|
exposes functions via DataSource or model classes.
|
|
|
|
#### LoopBack Connector Modules
|
|
|
|
| Type | Package Name |
|
|
| --------- | -------------------------------------------------------------------------------------- |
|
|
| Memory | [Built-in](https://github.com/strongloop/loopback-datasource-juggler) |
|
|
| MongoDB | [loopback-connector-mongodb](https://github.com/strongloop/loopback-connector-mongodb) |
|
|
| Oracle | [loopback-connector-oracle](https://github.com/strongloop/loopback-connector-oracle) |
|
|
| REST | [loopback-connector-rest](https://github.com/strongloop/loopback-connector-rest) |
|
|
|
|
For more information, please read the [LoopBack DataSource and Connector Guide](/loopback-datasource-juggler/#loopback-datasource-and-connector-guide).
|
|
|
|
### REST
|
|
|
|
Functions defined in LoopBack Models can be made available as a REST
|
|
endpoint. You can see and experiment with _your_ REST api using the
|
|
[LoopBack API Explorer](http://localhost:3000/explorer/).
|
|
|
|
LoopBack also supports other protocols for your API as well. Socket.io is
|
|
another protocol that is currently being developed.
|
|
|
|
For more information, please read [Model REST APIs](#model-rest-api).
|
|
|
|
### Remoting
|
|
|
|
With LoopBack you can add whatever functionality you like either
|
|
by yourself or leveraging functionality from other open source
|
|
modules from the community. The ability to "mix in" behaviors are
|
|
available through the inherent power of Javascript's less resrictive
|
|
inheritance model.
|
|
|
|
LoopBack takes this one step further by allowing you to seamlessly
|
|
invoke server side code running in LoopBack in the backend from the
|
|
your client on the front end.
|
|
|
|
For more information, please read the [Remoting Guide](/strong-remoting).
|
|
|
|
### The Big Picture
|
|
|
|
LoopBack's overall representation is illustrated below through its
|
|
runtime sub-components:
|
|
|
|
- Mobile Clients
|
|
- API Gateway - ***Coming Soon***
|
|
- API Server
|
|
- Enterprise Connectors
|
|
|
|
As well as its management sub-components:
|
|
|
|
- Editor - ***Coming Soon***
|
|
- Admin Console - ***Coming Soon***
|
|
- LoopBack Node.js API
|
|
- Repository/Registry
|
|
|
|
![loopback_overview](assets/loopback_ov.png "LoopBack Overview")
|
|
|
|
At first glance, LoopBack looks like just any other API tier. But
|
|
looks can be deceiving. Here are some key differentiators that make
|
|
Loopback stand out as an api tier built for mobile:
|
|
|
|
1. Model APIS are surfaced over REST without writing code
|
|
2. The Datasource Juggler is a modern ORM that supports
|
|
not only traditional RDBMS, but also noSQL and services
|
|
3. As a mobile backend as a service (mBaaS) we help you leverage
|
|
valuable existing data in your mobile app as well dynamically create
|
|
new schema or schema-less data
|
|
|
|
<h4> Mobile clients </h4>
|
|
We're putting a lot of effort into building flexibility and
|
|
functionality into our mobile client SDKs. The ultimate goal is to
|
|
preserve what's familiar to the mobile developer in their native
|
|
platform and empower them with seamelss backend functionality.
|
|
|
|
Mobile clients call into LoopBack APIs surfaced by [strong-remoting](http://docs.strongloop.com/strong-remoting), a pluggable transport
|
|
layer that supports surfacing backend APIs over REST, WebSockets,
|
|
and other transports.
|
|
|
|
<h4> API Gateway </h4>
|
|
The first line of defense and entry is the API gateway. This
|
|
sub-component of LoopBack acts as a reverse-proxy to the rest of
|
|
LoopBack. It provides OAuth2 based security, will mediate between
|
|
multiple data formats and acts as a quality of service layer for your
|
|
API providing instrumentation and other aspect level functionality.
|
|
|
|
<h4> API Server </h4>
|
|
The core of LoopBack is the API Server where models are registered
|
|
and hosted during runtime. Models are automatically exposed through a REST endpoint.
|
|
|
|
The API server also will run batch processes or scheduled jobs as a
|
|
mobile backend for functions like mass push notifications.
|
|
|
|
<h4> Enterprise Connectors </h4>
|
|
LoopBack lets you leveratge existing data and services that you need
|
|
in your mobile apps just as you do in your web apps. LoopBack has a
|
|
layer of abstraction provided by the DataSource Juggler so that all
|
|
you need to worry about is your model. The Datasource Juggler
|
|
accesses the underlying [datasources](http://docs.strongloop.com/loopback/#data-sources-and-connectors) through Enterprise
|
|
Connectors.
|
|
|
|
<h4> Editor </h4>
|
|
LoopBack comes with a rich set of [Node.js based APIs](http://docs.strongloop.com/loopback/#nodejs-api).
|
|
The editor is a web based GUI that makes it even easier to define,
|
|
configure and manage your mobile apps and models without having to
|
|
write code. The editor will also facilitate the process of
|
|
[discovering models](http://docs.strongloop.com/loopback/#datasourcediscovermodeldefinitionsusername-fn) and [schemas](http://docs.strongloop.com/loopback/#datasourcediscoverschemaowner-name-fn)
|
|
from datasources to give you a headstart on building your app.
|
|
|
|
<h4> Admin Console </h4>
|
|
Each LoopBack development environment is fully self contained. When
|
|
working in the enterprise, there is a need to distribute work much
|
|
like how distributed source control systems like `git` have risen and
|
|
evolved. When combining the work output from multiple LoopBack
|
|
development environments into a single enterprise runtime, the Admin
|
|
Console helps with merging and maintaining configuration as well as
|
|
deployment.
|
|
|
|
|
|
<h4> Repository </h4>
|
|
All development in LoopBack ends up as metadata that's stored in JSON
|
|
config files. Config files are distributed, merged and
|
|
consolidated centrally into the Repository. The Repository is
|
|
centrally maintained by an admin through the [Admin
|
|
Console](http://docs.strongloop.com/loopback#admin-console) where
|
|
policies like security are defined and configured.
|
|
|
|
|
|
<h4> LoopBack Node.js API </h4>
|
|
All manipulation of the metadata that constitutes the entire runtime
|
|
of the mobile API is done through an internal Node.js API. In the
|
|
spirit of truly "eating our own dog food" - the API powers the
|
|
editor and any other tools that are included with LoopBack.
|
|
|
|
|
|
|
|
---
|