express-mesh
v0.1.27
Published
A Gentics Mesh frontend for Express.
Downloads
471
Readme
express-mesh
An extension for express to serve content from Gentics Mesh.
To get/download Gentics Mesh, check out http://getmesh.io/.
Features
- Serve websites powerded by Gentics Mesh
- Swig template engine
- Custom template filters
- Custom schema, error and view handlers
- Usable with pure JavaScript and TypeScript
- Completely typed API with TypeScript
How to install
1. Install express-mesh
npm install -save express-mesh
Basic Usage
Below is a minimal express app will serve content from a local mesh installation.
var express = require('express');
var http = require('http');
var path = require('path');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var session = require('express-session');
var swig = require('swig');
var expressCompression = require('compression');
var cons = require('consolidate');
var mesh = require('express-mesh');
var port = process.env.PORT || 8089,
app = express(),
server = http.createServer(app),
viewDir = __dirname + '/views',
Mesh = new mesh.Mesh(app,mesh.MeshConfig.createSimpleConfiguration('demo'));
app.set('views', viewDir);
app.engine('html', cons.swig);
app.set('view engine', 'html');
app.use(expressCompression());
app.use(cookieParser());
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
app.use(session({
secret: 'mysupersecuresessionsecret',
resave: false,
saveUninitialized: false
}));
// serving of static resources
app.use(express.static(path.join(__dirname, 'public')));
// if we want to have the mesh template filters, we need to register them
Mesh.registerTemplateFilters(swig);
// initialize the mesh frontend
Mesh.server(app);
server.listen(port, () => {
console.log("Express server listening on port " + port);
});