项目作者: sendanor

项目描述 :
Sendanor Hypermedia App Server
高级语言: JavaScript
项目地址: git://github.com/sendanor/nor-app.git
创建时间: 2016-07-30T17:07:40Z
项目社区:https://github.com/sendanor/nor-app

开源协议:MIT License

下载


view on npm
npm module downloads
Dependency Status

nor-app — Hypermedia App Server

nor-app provides a HTTP interface in to a nor-nopg
database
— which provides noSQL features in a
PostgreSQL database server.

Features

  • Web based UI to maintain document types with JSON Schema
  • Web interface to create, search, edit and delete documents
  • Maintains a hypermedia JSON REST API for the data

See also

  • nopg — Shell scripting CLI for nor-nopg

Requirements

Development

Install

Installing globally

Install nor-nopg:

  1. npm install -g nor-nopg

Install nor-app:

  1. npm install -g nor-app

Creating a database

Create a PostgreSQL database with these extensions:

  1. CREATE EXTENSION plv8;
  2. CREATE EXTENSION "uuid-ossp";
  3. CREATE EXTENSION tcn;
  4. CREATE EXTENSION moddatetime;

Set your database configurations into a PGCONFIG environment variable:

  1. export PGCONFIG='postgres://app:password@localhost/app'

Setting name and port

Name your application (default name is nor-app):

  1. export APPNAME='myapp'

You can also change your application port (default port is 3000):

  1. export PORT='8080'

Initializing NoPG

  1. nor-nopg init

Start the server

  1. nor-app start

Check the logs at ~/.nor-app/logs/myapp/.

If there’s any problems, just create an issue.

Create admin user

  1. nor-app-useradd --email='demo@example.com'

Write down the password, you need it to login :)

Installing as a dependency

You may want to use nor-app as a dependency instead of a global command.

Create a directory for your project and initialize NPM there:

  1. mkdir myapp
  2. cd myapp
  3. npm init
  4. npm install --save nor-nopg
  5. npm install --save nor-app

…then edit scripts section in your ./package.json to look like this:

  1. {
  2. "scripts": {
  3. "test": "echo \"Error: no test specified\" && exit 1",
  4. "init": "nor-nopg init",
  5. "start": "nor-app start",
  6. "stop": "nor-app stop"
  7. }
  8. }

After that, you can initialize the NoPg database with a command
npm run init instead of nor-nopg init and start the server simply
with a command npm start and stop it npm stop.

After installation

Open your browser at http://localhost:3000 and login

… and design your database in the browser…

… and access REST interface from: http://localhost:3000/api/

Troubleshooting

If something doesn’t work, check log files at ~/.nor-app/logs/myapp/.

Testing API

We recommend using jsonview when working in Google Chrome.

Testing API with curl

We also have a curl wrapper ./tools/curl which makes it easier to work with our API.

Easiest way to get a cookie is from logged in session using Google Chrome’s inspector.

Copy the value of connect.sid:

  1. npm config set nor-app:curl_cookie 'connect.sid=your-value-here'

Then you can use the api:

  1. ./tools/curl http://localhost:3000/api/