deep-core
Advanced tools
Comparing version 1.0.5 to 1.0.6
@@ -24,2 +24,6 @@ /** | ||
var _ExceptionInvalidCognitoIdentityException = require('./Exception/InvalidCognitoIdentityException'); | ||
var _ExceptionMissingUserContextException = require('./Exception/MissingUserContextException'); | ||
/** | ||
@@ -44,6 +48,12 @@ * Lambda runtime context | ||
this._context = null; | ||
this._loggedUserId = null; | ||
this._forceUserIdentity = false; | ||
this._fillDenyMissingUserContextOption(); | ||
this._fillUserContext(); | ||
} | ||
/** | ||
* @returns {Object} | ||
* @returns {String} | ||
*/ | ||
@@ -64,2 +74,7 @@ | ||
this._request = new _Request.Request(event); | ||
if (!this._loggedUserId && this._forceUserIdentity) { | ||
throw new _ExceptionMissingUserContextException.MissingUserContextException(); | ||
} | ||
this.handle(this._request); | ||
@@ -126,2 +141,50 @@ | ||
}, { | ||
key: '_fillDenyMissingUserContextOption', | ||
/** | ||
* @private | ||
*/ | ||
value: function _fillDenyMissingUserContextOption() { | ||
if (this._kernel.config.hasOwnProperty('forceUserIdentity')) { | ||
this._forceUserIdentity = this._kernel.config.forceUserIdentity; | ||
} | ||
} | ||
/** | ||
* Retrieves logged user id from lambda context | ||
* | ||
* @private | ||
*/ | ||
}, { | ||
key: '_fillUserContext', | ||
value: function _fillUserContext() { | ||
if (this._context && this._context.hasOwnProperty('identity') && this._context.identity.hasOwnProperty('cognitoIdentityPoolId') && this._context.identity.hasOwnProperty('cognitoIdentityId')) { | ||
var identityPoolId = this._context.identity.cognitoIdentityPoolId; | ||
if (this.securityService.identityPoolId !== identityPoolId) { | ||
throw new _ExceptionInvalidCognitoIdentityException.InvalidCognitoIdentityException(identityPoolId); | ||
} | ||
this._loggedUserId = this._context.identity.cognitoIdentityId; | ||
} | ||
} | ||
}, { | ||
key: 'loggedUserId', | ||
get: function get() { | ||
return this._loggedUserId; | ||
} | ||
/** | ||
* @returns {Boolean} | ||
*/ | ||
}, { | ||
key: 'forceUserIdentity', | ||
get: function get() { | ||
return this._forceUserIdentity; | ||
} | ||
/** | ||
* @returns {Object} | ||
*/ | ||
}, { | ||
key: 'kernel', | ||
@@ -149,2 +212,11 @@ get: function get() { | ||
} | ||
/** | ||
* @returns {Object} | ||
*/ | ||
}, { | ||
key: 'securityService', | ||
get: function get() { | ||
return this.kernel.get('security'); | ||
} | ||
}]); | ||
@@ -151,0 +223,0 @@ |
{ | ||
"name": "deep-core", | ||
"version": "1.0.5", | ||
"version": "1.0.6", | ||
"description": "DEEP Core Library", | ||
@@ -5,0 +5,0 @@ "keywords": [ |
225
README.md
@@ -1,70 +0,130 @@ | ||
deep-core | ||
========= | ||
DEEP Core Library (deep-core) | ||
============== | ||
[![NPM Version](https://img.shields.io/npm/v/deep-core.svg)](https://npmjs.org/package/deep-core) | ||
[![Build Status](https://travis-ci.org/MitocGroup/deep-framework.svg)](https://travis-ci.org/MitocGroup/deep-framework) | ||
[![Coverage Status](https://coveralls.io/repos/MitocGroup/deep-framework/badge.svg?service=github&t=3QEkFa)](https://coveralls.io/github/MitocGroup/deep-framework) | ||
[![Codacy Badge](https://api.codacy.com/project/badge/630b5f0024334dc09fd0299b1a8a0ed5)](https://www.codacy.com/app/MitocGroup/deep-framework) | ||
[![API Docs](http://docs.deep.mg/deep-core/badge.svg)](http://docs.deep.mg/deep-core/) | ||
[![NPM Version](https://img.shields.io/npm/v/deep-framework.svg)](https://npmjs.org/package/deep-framework) | ||
[![Build Status](https://travis-ci.org/MitocGroup/deep-framework.svg?branch=master)](https://travis-ci.org/MitocGroup/deep-framework) | ||
[![Codacy Badge](https://api.codacy.com/project/badge/coverage/823d04a90c4a4fc888e62817e3e820be)](https://www.codacy.com/app/MitocGroup/deep-framework) | ||
[![API Docs](http://docs.deep.mg/badge.svg)](http://docs.deep.mg) | ||
[deep-core](https://www.npmjs.com/package/deep-core) is a node.js library, part of [DEEP Framework](https://github.com/MitocGroup/deep-framework). | ||
`DEEP Framework` is a core component of the | ||
[Platform-as-a-Service](https://github.com/MitocGroup/deep-framework/blob/master/README.md#appendix-b-deep-ecosystem) | ||
that abstracts web services from specific cloud providers. This framework enables developers build web applications | ||
or platforms using [microservices architecture](https://en.wikipedia.org/wiki/Microservices) in a completely | ||
[serverless approach](https://github.com/MitocGroup/deep-framework#appendix-a-serverless-architecture). | ||
![Digital Enterprise End-to-end Platform, aka DEEP](https://raw.githubusercontent.com/MitocGroup/deep-framework/master/docs/deep-ecosystem.png) | ||
> At this moment only [Amazon Web Services](https://aws.amazon.com) is supported. Developers are encouraged to add support | ||
for [Microsoft Azure](https://azure.microsoft.com), [Google Cloud Platform](https://cloud.google.com/), and so on. | ||
Digital Enterprise End-to-end Platform (also known as DEEP) is low cost and low maintenance digital platform powered by abstracted services from AWS. We enable businesses and developers to achieve more by doing less. | ||
## Getting Started [![Join char on gitter.im](https://img.shields.io/badge/%E2%8A%AA%20gitter%20-join%20chat%20%E2%86%92-brightgreen.svg)](https://gitter.im/MitocGroup/deep-framework) | ||
## DEEP for Businesses [![Join char on gitter.im](https://img.shields.io/badge/%E2%8A%AA%20gitter%20-join%20chat%20%E2%86%92-brightgreen.svg)](https://gitter.im/MitocGroup/deep-framework) | ||
`DEEP Framework` can be used as a module in front-end or back-end. To learn more, scroll down to | ||
[What is DEEP Framework?](https://github.com/MitocGroup/deep-framework/blob/master/README.md#what-is-deep-framework-) | ||
#### User Guide Documentation (to be updated later) | ||
To see the power of `DEEP Framework`, execute the following 4 simple steps in command line: | ||
DEEP is enabling small and medium businesses, as well as enterprises to: | ||
- Rent applications on a monthly basis by needed functionality from [DEEP Marketplace](https://www.deep.mg) | ||
- Choose applications by desired features and deploy them securely in their own accounts from cloud providers like AWS | ||
- Pay only for subscribed applications and stop paying when unsubscribing and not using anymore | ||
- Run secured, self-service applications with beautiful user interfaces and intuitively simple user experiences | ||
- Empower none technical teams to solve business problems through technology, without waiting on technical teams' availability | ||
1. `npm install deepify -g` # Install DEEP CLI, also known as deepify | ||
> deepify is a collection of tools that empower developers and devops engineers to automate | ||
the management of web apps built on top of DEEP ecosystem. | ||
> [DEEP Marketplace](https://www.deep.mg) (aka [www.deep.mg](https://www.deep.mg)) is a web application built using DEEP and published on serverless environment from [Amazon Web Services](https://aws.amazon.com) (aka [aws.amazon.com](https://aws.amazon.com)). We make it faster and easier for developers to build and publish their software, as well as for businesses to discover and test applications they are looking for. Our goal is to connect businesses with developers, and empower technical teams to build self-service software that none technical teams could use. The marketplace is like Apple's App Store for web applications that run natively on cloud providers like AWS. | ||
2. `deepify helloworld ~/deep-hello-world` # Using deepify, dump locally the helloworld example | ||
> deepify will clone the repository from GitHub and pull all the dependencies in one place. | ||
## DEEP for Developers [![Join char on gitter.im](https://img.shields.io/badge/%E2%8A%AA%20gitter%20-join%20chat%20%E2%86%92-brightgreen.svg)](https://gitter.im/MitocGroup/deep-framework) | ||
3. `deepify server ~/deep-hello-world -o` # Using deepify, run locally the helloworld example | ||
> deepify launches a web server that can be used for local development, without making calls | ||
to web services from cloud providers like AWS. | ||
#### [API Guide Documentation](http://docs.deep.mg) | ||
#### [Developer Guide Documentation](https://github.com/MitocGroup/deep-framework/blob/master/docs/index.md) | ||
4. `deepify deploy ~/deep-hello-world` # Using deepify, deploy to AWS the helloworld example | ||
> deepify provisions the infrastructure and deploys the web app, empowering developers and | ||
devops engineers to automate the process. | ||
DEEP is enabling developers and architects to: | ||
- Design microservices architecture on top of serverless environments from cloud providers like AWS | ||
- Build distributed software that combines and manages hardware and software in the same microservice | ||
- Use the framework's abstracted approach to build applications that could be cloud agnostic | ||
- Build cloud native JavaScript applications that combine and manage frontend, backend and database layers in the same [DEEP Microservice](https://github.com/MitocGroup/deep-framework/blob/master/docs/microservice.md) | ||
- Run in the cloud the software that was built by distributed teams and served self-service in large organizations | ||
- Monetize their work of art by uploading microservices to [DEEP Marketplace](https://www.deep.mg) | ||
To learn more about helloworld example, or other web apps that run in production, scroll down to | ||
[Who is using DEEP Framework?](https://github.com/MitocGroup/deep-framework/blob/master/README.md#who-is-using-deep-framework-) | ||
> [DEEP Microservice](https://github.com/MitocGroup/deep-framework/blob/master/docs/microservice.md) is the predefined structure of a microservice (an application) in DEEP. There is clear separation between frontend, backend and database, as well as unit tests and documentation. Developers are encoraged to get started with [DEEP Microservices HelloWorld](https://github.com/MitocGroup/deep-microservices-helloworld) or [DEEP Microservices ToDo App](https://github.com/MitocGroup/deep-microservices-todo-app), as well as [DEEP CLI](https://www.npmjs.com/package/deepify) (aka `deepify`). | ||
### Additional Notes | ||
Note 1: To use `DEEP Framework` globally, just run in command line: | ||
``` | ||
npm install deep-framework -g | ||
``` | ||
> [DEEP Marketplace](https://www.deep.mg) (aka [www.deep.mg](https://www.deep.mg)) is a web application built using DEEP and published on serverless environment from [Amazon Web Services](https://aws.amazon.com) (aka [aws.amazon.com](https://aws.amazon.com)). We make it faster and easier for developers to build and publish their software, as well as for businesses to discover and test applications they are looking for. Our goal is to connect businesses with developers, and empower technical teams to build self-service software that none technical teams could use. The marketplace is like Apple's App Store for web applications that run natively on cloud providers like AWS. | ||
Note 2: Alternatively, to use `DEEP Framework` as dependency, include it in `package.json` file. For example: | ||
``` | ||
{ | ||
"name": "say-hello-world", | ||
"version": "0.0.1", | ||
"description": "AWS Lambda that says hello to the world", | ||
"dependencies": { | ||
"deep-framework": "1.0.*", | ||
... | ||
}, | ||
... | ||
} | ||
``` | ||
## DEEP Architecture on AWS [![Join char on gitter.im](https://img.shields.io/badge/%E2%8A%AA%20gitter%20-join%20chat%20%E2%86%92-brightgreen.svg)](https://gitter.im/MitocGroup/deep-framework) | ||
Note 3: Also, when needed, consider specifying only some libraries instead of entire framework. For example: | ||
``` | ||
{ | ||
"name": "say-hello-world", | ||
"version": "0.0.1", | ||
"description": "AWS Lambda that says hello to the world", | ||
"dependencies": { | ||
"deep-db": "1.0.*", | ||
"deep-event": "1.0.*", | ||
"deep-resource": "1.0.*", | ||
... | ||
}, | ||
... | ||
} | ||
``` | ||
![Digital Enterprise End-to-end Platform, aka DEEP](https://raw.githubusercontent.com/MitocGroup/deep-framework/master/docs/deep-architecture.png) | ||
## What is DEEP Framework? [![Join char on gitter.im](https://img.shields.io/badge/%E2%8A%AA%20gitter%20-join%20chat%20%E2%86%92-brightgreen.svg)](https://gitter.im/MitocGroup/deep-framework) | ||
DEEP is using [microservices architecture](https://en.wikipedia.org/wiki/Microservices) on serverless environments from cloud providers like AWS. DEEP Framework abstracts the functionality and makes it completely developer friendly. We have the following abstracted libraries: | ||
`DEEP Framework` is a nodejs package that is published on npmjs: https://www.npmjs.com/package/deep-framework. | ||
DEEP Abstracted Library | Description | AWS Abstracted Service(s) | ||
-------------|---------------------|-------------------------- | ||
[deep-asset](http://docs.deep.mg/deep-asset) | Assets Management Library | Amazon S3 | ||
[deep-cache](http://docs.deep.mg/deep-cache) | Cache Management Library | Amazon ElastiCache | ||
[deep-core](http://docs.deep.mg/deep-core) | Core Management Library | - | ||
[deep-db](http://docs.deep.mg/deep-db) | Database Management Library | Amazon DynamoDB, Amazon SQS | ||
[deep-di](http://docs.deep.mg/deep-di) | Dependency Injection Management Library | - | ||
[deep-event](http://docs.deep.mg/deep-event) | Events Management Library | Amazon Kinesis | ||
[deep-fs](http://docs.deep.mg/deep-fs) | File System Management Library | Amazon S3 | ||
[deep-kernel](http://docs.deep.mg/deep-kernel) | Kernel Management Library | - | ||
[deep-log](http://docs.deep.mg/deep-log) | Logs Management Library | Amazon CloudWatch Logs | ||
[deep-notification](http://docs.deep.mg/deep-notification) | Notifications Management Library | Amazon SNS | ||
[deep-resource](http://docs.deep.mg/deep-resource) | Resouces Management Library | AWS Lambda, Amazon API Gateway | ||
[deep-security](http://docs.deep.mg/deep-security) | Security Management Library | AWS IAM, Amazon Cognito | ||
[deep-validation](http://docs.deep.mg/deep-validation) | Validation Management Library | - | ||
> If you are new to node and npm, check out [how to install nodejs](http://howtonode.org/how-to-install-nodejs) tutorial. | ||
## Feedback | ||
`DEEP Framework` is a nodejs package. In fact it's a collection of nodejs packages, also known as | ||
`DEEP Abstracted Libraries`. Here below is the complete list: | ||
DEEP Abstracted Library | [Api Docs](http://docs.deep.mg/) | Abstracted Web Service(s) | ||
------------------------|-------------------------------|-------------------------- | ||
[deep-asset](https://www.npmjs.com/package/deep-asset) | [Assets Management Library](http://docs.deep.mg/deep-asset) | Amazon S3 | ||
[deep-cache](https://www.npmjs.com/package/deep-cache) | [Cache Management Library](http://docs.deep.mg/deep-cache) | Amazon ElastiCache | ||
[deep-core](https://www.npmjs.com/package/deep-core) | [Core Management Library](http://docs.deep.mg/deep-core) | - | ||
[deep-db](https://www.npmjs.com/package/deep-db) | [Database Management Library](http://docs.deep.mg/deep-db) | Amazon DynamoDB, Amazon SQS | ||
[deep-di](https://www.npmjs.com/package/deep-di) | [Dependency Injection Management Library](http://docs.deep.mg/deep-di) | - | ||
[deep-event](https://www.npmjs.com/package/deep-event) | [Events Management Library](http://docs.deep.mg/deep-event) | Amazon Kinesis | ||
[deep-fs](https://www.npmjs.com/package/deep-fs) | [File System Management Library](http://docs.deep.mg/deep-fs) | Amazon S3 | ||
[deep-kernel](https://www.npmjs.com/package/deep-kernel) | [Kernel Management Library](http://docs.deep.mg/deep-kernel) | - | ||
[deep-log](https://www.npmjs.com/package/deep-log) | [Logs Management Library](http://docs.deep.mg/deep-log) | Amazon CloudWatch Logs | ||
[deep-notification](https://www.npmjs.com/package/deep-notification) | [Notifications Management Library](http://docs.deep.mg/deep-notification) | Amazon SNS | ||
[deep-resource](https://www.npmjs.com/package/deep-resource) | [Resouces Management Library](http://docs.deep.mg/deep-resource) | AWS Lambda, Amazon API Gateway | ||
[deep-security](https://www.npmjs.com/package/deep-security) | [Security Management Library](http://docs.deep.mg/deep-security) | AWS IAM, Amazon Cognito | ||
[deep-validation](https://www.npmjs.com/package/deep-validation) | [Validation Management Library](http://docs.deep.mg/deep-validation) | - | ||
## Who is using DEEP Framework? [![Join char on gitter.im](https://img.shields.io/badge/%E2%8A%AA%20gitter%20-join%20chat%20%E2%86%92-brightgreen.svg)](https://gitter.im/MitocGroup/deep-framework) | ||
There are couple examples / web apps that are using `DEEP Framework` at their core: | ||
### DEEP Hello World | ||
> DEEP Hello World (https://github.com/MitocGroup/deep-microservices-helloworld) is a web app | ||
that show cases a full stack example of using DEEP Microservices in the context of Platform-as-a-Service. | ||
Developers can either fork this repository or `npm install deepify -g` (https://www.npmjs.com/package/deepify) | ||
and run in the command line `deepify helloworld ~/deep-hello-world`. | ||
### DEEP Todo App | ||
> DEEP Todo App (https://github.com/MitocGroup/deep-microservices-todo-app) is a web app inspired from | ||
AngularJS TodoMVC Example (https://github.com/tastejs/todomvc/tree/master/examples/angularjs). | ||
It reuses AngularJS module and integrates using `DEEP Framework` to streamline development and deployment | ||
using cloud-based web services. | ||
### DEEP Marketplace | ||
> DEEP Marketplace (https://www.deep.mg) is Software-as-a-Service, built on top of DEEP, that empowers customers | ||
to choose functionality from listed microservices and deploy them together as an web app into their own | ||
AWS accounts with just few clicks; as well as empowers developers to create and publish their microservices | ||
and monetize them in similar approach to Apple's App Store. | ||
## How can I get involved? [![Join char on gitter.im](https://img.shields.io/badge/%E2%8A%AA%20gitter%20-join%20chat%20%E2%86%92-brightgreen.svg)](https://gitter.im/MitocGroup/deep-framework) | ||
### Feedback | ||
We are eager to get your feedback, so please use whatever communication channel you prefer: | ||
@@ -75,10 +135,71 @@ - [github issues](https://github.com/MitocGroup/deep-framework/issues) | ||
## License | ||
### Contribution | ||
This project is open source, and we encourage developers to contribute. Here below is the easiest way to do so: | ||
1. [Fork](http://help.github.com/forking/) this repository in GitHub. | ||
2. Develop the feature in your repository. Make one or more commits to your repository in GitHub. | ||
3. Perform a [pull request](http://help.github.com/pull-requests/) from your repository back into original repository in GitHub. | ||
Make sure you update `package.json` (or `deepkg.json`, depends on the use case) and put your name and contact information in contributors section. We would like to recognize the work and empower every contributor in creative ways :) | ||
### Roadmap | ||
Our short-to-medium-term roadmap items, in order of descending priority: | ||
Feature | Details | Owner | ||
--------|---------|------ | ||
Implement deep-security | Security service on top of [IAM](https://aws.amazon.com/iam/) | [@mgoria](https://github.com/mgoria) | ||
Implement deep-notification | Push notification service on top of [SNS](https://aws.amazon.com/sns/) that supports push to mobile devices, web browsers, email and sms. | [@alexanderc](https://github.com/alexanderc) | ||
Implement deep-search | Full text search service on top of [Amazon CloudSearch](https://aws.amazon.com/cloudsearch/) | [@alexanderc](https://github.com/alexanderc) | ||
Implement deep-event | Event manager service using Lambda scheduling, Kinesis stream, Dynamo streaming, SQS, etc. | ... | ||
Implement deep-db "eventual consistency" | Achieve "eventual consistency" by offloading data to [SQS](https://aws.amazon.com/sqs/) as the default option | [@alexanderc](https://github.com/alexanderc) | ||
Improve deep-db "strong consistency" | Achieve "strong consistency" by increasing Reads/Writes per second in runtime (as other option for special DB operations) | ... | ||
Integrate deep-db with deep-cache natively (blocked by VPC support in Lambda) | Cache fetched data by default using deep-cache library | ... | ||
Implement deep-cache | Cache service on top of [Elasticache](https://aws.amazon.com/elasticache/) ([Redis](http://redis.io)) inside Lambdas (blocked by VPC support in Lambda) | ... | ||
Implement [RUM](https://en.wikipedia.org/wiki/Real_user_monitoring) as part of deep-logs | Achieve real user monitoring by logging all user actions and visualize them with an [ELK stack](https://www.elastic.co/webinars/introduction-elk-stack) | ... | ||
Optimize the framework to reduce the size of Lambda functions | Optimize deps and packing as well as browserify process to reduce framework size | [@alexanderc](https://github.com/alexanderc) | ||
Improve documentation for each deep-* library | Update docs for deep libraries and development tools | [@alexanderc](https://github.com/alexanderc) [@mgoria](https://github.com/mgoria) | ||
### Changelog | ||
Changelog files are located in `/changelog` folder. | ||
> See [CHANGELOG.md](https://github.com/MitocGroup/deep-framework/blob/master/CHANGELOG.md) for latest changelog. | ||
### License | ||
This repository can be used under the MIT license. | ||
> See [LICENSE](https://github.com/MitocGroup/deep-framework/blob/master/LICENSE) for more details. | ||
## Sponsors | ||
### Sponsors | ||
This repository is being sponsored by: | ||
> [Mitoc Group](http://www.mitocgroup.com) | ||
## What else is relevant? [![Join char on gitter.im](https://img.shields.io/badge/%E2%8A%AA%20gitter%20-join%20chat%20%E2%86%92-brightgreen.svg)](https://gitter.im/MitocGroup/deep-framework) | ||
`Digital Enterprise End-to-end Platform`, also known as `DEEP`, is low cost and low maintenance | ||
[Platform-as-a-Service](https://en.wikipedia.org/wiki/Platform_as_a_service) powered by abstracted web services | ||
from cloud providers like [Amazon Web Services](https://aws.amazon.com). This approach has been labeled as | ||
[Serverless Architecture](https://github.com/MitocGroup/deep-framework/blob/master/README.md#appendix-a-serverless-architecture). | ||
### Appendix A: Serverless Architecture | ||
![Digital Enterprise End-to-end Platform aka DEEP](https://raw.githubusercontent.com/MitocGroup/deep-framework/master/docs/deep-architecture.png) | ||
`DEEP` is an ecosystem of [DEEP Marketplace](https://www.deep.mg), | ||
[DEEP Framework](https://github.com/MitocGroup/deep-framework) and [DEEP CLI](https://www.npmjs.com/package/deepify), | ||
also known as [deepify](https://www.npmjs.com/package/deepify). It enables developers build serverless applications | ||
using abstracted services from cloud providers like [Amazon Web Services](https://aws.amazon.com). | ||
### Appendix B: DEEP Ecosystem | ||
![Digital Enterprise End-to-end Platform aka DEEP](https://raw.githubusercontent.com/MitocGroup/deep-framework/master/docs/deep-ecosystem.png) | ||
`DEEP` aims to remove the heavy lifting from enterprise software through microservices architecture, where developers | ||
(let’s label them `lego producers`) focus only to build microservices (let’s label them `lego pieces`), while the platform | ||
does the rest: comes pre-built and pre-scaled, low-cost and low-maintenance, very secure and very fast. Customers | ||
(let’s label them `lego consumers`) will go to the marketplace, choose the microservices they need and deploy them | ||
as web apps into their own accounts on AWS (or other cloud providers). | ||
> In summary: We empowers lego consumers to license curated lego pieces from lego producers. |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
89157
28
1787
205