diff --git a/loopback-blog/.editorconfig b/loopback-blog/.editorconfig new file mode 100644 index 0000000..3ee22e5 --- /dev/null +++ b/loopback-blog/.editorconfig @@ -0,0 +1,13 @@ +# EditorConfig helps developers define and maintain consistent +# coding styles between different editors and IDEs +# http://editorconfig.org + +root = true + +[*] +indent_style = space +indent_size = 2 +end_of_line = lf +charset = utf-8 +trim_trailing_whitespace = true +insert_final_newline = true diff --git a/loopback-blog/.eslintignore b/loopback-blog/.eslintignore new file mode 100644 index 0000000..44f3970 --- /dev/null +++ b/loopback-blog/.eslintignore @@ -0,0 +1 @@ +/client/ \ No newline at end of file diff --git a/loopback-blog/.eslintrc b/loopback-blog/.eslintrc new file mode 100644 index 0000000..a6e5297 --- /dev/null +++ b/loopback-blog/.eslintrc @@ -0,0 +1,3 @@ +{ + "extends": "loopback" +} \ No newline at end of file diff --git a/loopback-blog/.gitignore b/loopback-blog/.gitignore new file mode 100644 index 0000000..aff1045 --- /dev/null +++ b/loopback-blog/.gitignore @@ -0,0 +1,19 @@ +*.csv +*.dat +*.iml +*.log +*.out +*.pid +*.seed +*.sublime-* +*.swo +*.swp +*.tgz +*.xml +.DS_Store +.idea +.project +.strong-pm +coverage +node_modules +npm-debug.log diff --git a/loopback-blog/.yo-rc.json b/loopback-blog/.yo-rc.json new file mode 100644 index 0000000..02f3fc1 --- /dev/null +++ b/loopback-blog/.yo-rc.json @@ -0,0 +1,3 @@ +{ + "generator-loopback": {} +} \ No newline at end of file diff --git a/loopback-blog/client/README.md b/loopback-blog/client/README.md new file mode 100644 index 0000000..dd00c9e --- /dev/null +++ b/loopback-blog/client/README.md @@ -0,0 +1,3 @@ +## Client + +This is the place for your application front-end files. diff --git a/loopback-blog/package.json b/loopback-blog/package.json new file mode 100644 index 0000000..7fc8f9f --- /dev/null +++ b/loopback-blog/package.json @@ -0,0 +1,34 @@ +{ + "name": "loopback-blog", + "version": "1.0.0", + "main": "server/server.js", + "engines": { + "node": ">=4" + }, + "scripts": { + "lint": "eslint .", + "start": "node .", + "posttest": "npm run lint && nsp check" + }, + "dependencies": { + "compression": "^1.0.3", + "cors": "^2.5.2", + "helmet": "^1.3.0", + "loopback-boot": "^2.6.5", + "serve-favicon": "^2.0.1", + "strong-error-handler": "^2.0.0", + "loopback-component-explorer": "^4.0.0", + "loopback": "^3.0.0" + }, + "devDependencies": { + "eslint": "^3.17.1", + "eslint-config-loopback": "^8.0.0", + "nsp": "^2.1.0" + }, + "repository": { + "type": "", + "url": "" + }, + "license": "UNLICENSED", + "description": "loopback-blog" +} diff --git a/loopback-blog/server/boot/root.js b/loopback-blog/server/boot/root.js new file mode 100644 index 0000000..6adce90 --- /dev/null +++ b/loopback-blog/server/boot/root.js @@ -0,0 +1,8 @@ +'use strict'; + +module.exports = function(server) { + // Install a `/` route that returns server status + var router = server.loopback.Router(); + router.get('/', server.loopback.status()); + server.use(router); +}; diff --git a/loopback-blog/server/component-config.json b/loopback-blog/server/component-config.json new file mode 100644 index 0000000..f36959a --- /dev/null +++ b/loopback-blog/server/component-config.json @@ -0,0 +1,5 @@ +{ + "loopback-component-explorer": { + "mountPath": "/explorer" + } +} diff --git a/loopback-blog/server/config.json b/loopback-blog/server/config.json new file mode 100644 index 0000000..d371cd2 --- /dev/null +++ b/loopback-blog/server/config.json @@ -0,0 +1,22 @@ +{ + "restApiRoot": "/api", + "host": "0.0.0.0", + "port": 3000, + "remoting": { + "context": false, + "rest": { + "handleErrors": false, + "normalizeHttpPath": false, + "xml": false + }, + "json": { + "strict": false, + "limit": "100kb" + }, + "urlencoded": { + "extended": true, + "limit": "100kb" + }, + "cors": false + } +} diff --git a/loopback-blog/server/datasources.json b/loopback-blog/server/datasources.json new file mode 100644 index 0000000..0967ef4 --- /dev/null +++ b/loopback-blog/server/datasources.json @@ -0,0 +1 @@ +{} diff --git a/loopback-blog/server/middleware.development.json b/loopback-blog/server/middleware.development.json new file mode 100644 index 0000000..071c11a --- /dev/null +++ b/loopback-blog/server/middleware.development.json @@ -0,0 +1,10 @@ +{ + "final:after": { + "strong-error-handler": { + "params": { + "debug": true, + "log": true + } + } + } +} diff --git a/loopback-blog/server/middleware.json b/loopback-blog/server/middleware.json new file mode 100644 index 0000000..fbfff81 --- /dev/null +++ b/loopback-blog/server/middleware.json @@ -0,0 +1,50 @@ +{ + "initial:before": { + "loopback#favicon": {} + }, + "initial": { + "compression": {}, + "cors": { + "params": { + "origin": true, + "credentials": true, + "maxAge": 86400 + } + }, + "helmet#xssFilter": {}, + "helmet#frameguard": { + "params": [ + "deny" + ] + }, + "helmet#hsts": { + "params": { + "maxAge": 0, + "includeSubdomains": true + } + }, + "helmet#hidePoweredBy": {}, + "helmet#ieNoOpen": {}, + "helmet#noSniff": {}, + "helmet#noCache": { + "enabled": false + } + }, + "session": {}, + "auth": {}, + "parse": {}, + "routes": { + "loopback#rest": { + "paths": [ + "${restApiRoot}" + ] + } + }, + "files": {}, + "final": { + "loopback#urlNotFound": {} + }, + "final:after": { + "strong-error-handler": {} + } +} diff --git a/loopback-blog/server/model-config.json b/loopback-blog/server/model-config.json new file mode 100644 index 0000000..56f6800 --- /dev/null +++ b/loopback-blog/server/model-config.json @@ -0,0 +1,16 @@ +{ + "_meta": { + "sources": [ + "loopback/common/models", + "loopback/server/models", + "../common/models", + "./models" + ], + "mixins": [ + "loopback/common/mixins", + "loopback/server/mixins", + "../common/mixins", + "./mixins" + ] + } +} diff --git a/loopback-blog/server/server.js b/loopback-blog/server/server.js new file mode 100644 index 0000000..ef738ab --- /dev/null +++ b/loopback-blog/server/server.js @@ -0,0 +1,29 @@ +'use strict'; + +var loopback = require('loopback'); +var boot = require('loopback-boot'); + +var app = module.exports = loopback(); + +app.start = function() { + // start the web server + return app.listen(function() { + app.emit('started'); + var baseUrl = app.get('url').replace(/\/$/, ''); + console.log('Web server listening at: %s', baseUrl); + if (app.get('loopback-component-explorer')) { + var explorerPath = app.get('loopback-component-explorer').mountPath; + console.log('Browse your REST API at %s%s', baseUrl, explorerPath); + } + }); +}; + +// Bootstrap the application, configure models, datasources and middleware. +// Sub-apps like REST API are mounted via boot scripts. +boot(app, __dirname, function(err) { + if (err) throw err; + + // start the server if `$ node server.js` + if (require.main === module) + app.start(); +});