added beacon handler

This commit is contained in:
Martin Donnelly 2016-04-05 14:53:16 +01:00
parent 030c9ac7a3
commit 85ee70f344
3 changed files with 162 additions and 54 deletions

20
rebuild.sh Normal file
View File

@ -0,0 +1,20 @@
#!/bin/bash
NVM="$HOME/.nvm"
NVM_VERSION="5.7.0"
DEV="$HOME/dev"
LIVE="$HOME/live"
SWAP="/swapfile"
DBSETUP="obrand-admin-server/dbrebuild.sh"
PKG_MANAGER=$( command -v yum || command -v apt-get ) || echo "Neither yum nor apt-get found"
PKG_DEVICE=$(basename $PKG_MANAGER)
echo Copying...
cd $DEV/O-Brand/dist
cp -ra . $DEV/obrand-admin-server/wwwroot
cd $DEV/obrand-admin-server
rsync -uav --exclude .git $DEV/obrand-admin-server/ $LIVE

47
server/app/beacon.js Normal file
View File

@ -0,0 +1,47 @@
/**
*
* User: Martin Donnelly
* Date: 2016-04-05
* Time: 11:48
*
*/
/*jshint node:true*/
'use strict';
var db = require('../units/db-connector').dbConnection;
var dbPages = require('../units/db-pages')(db);
var logger = require('log4js').getLogger();
module.exports = function(app) {
var express = require('express');
var beaconRouter = express.Router();
beaconRouter.get('/', function(req, res) {
var beacon = {};
if (req.headers.hasOwnProperty('beacon')) {
beacon = JSON.parse(req.headers.beacon);
}
/* res.send({
beacon: beacon
});*/
logger.info('gettingLatestAddedPage');
dbPages.getLatestAddedPage()
.then((d) => {
logger.debug(d);
//res.status(407).end();
res.redirect(301, d.fullpath);
}).catch((err)=> {
console.error(err);
res.status(401).end();
});
});
app.use('/beacon', require('body-parser').json());
app.use('/beacon', require('body-parser').text());
app.use('/beacon', require('body-parser').urlencoded());
app.use('/beacon', beaconRouter);
};

View File

@ -16,70 +16,92 @@ module.exports = function(db) {
var module = {}; var module = {};
module.getLatestAddedPage = function() {
console.log('+ getLatestAddedPage');
//select '/export/' || pages.pid::text || '.html' as fullpath from pages order by id desc limit 1;
return new Promise(function(resolve, reject) {
db.oneOrNone(
"select 'export/' || pages.pid::text || '.html' as fullpath from pages order by id desc limit 1;")
.then((d) => {
console.log(d);
console.log('- getlastaddedpage');
return resolve(d);
})
.catch((err)=> {
console.log('+getLatestAddedPage failed');
console.log(err);
return reject(err);
});
});
};
module.getPageList = function() { module.getPageList = function() {
return new Promise(function(resolve, reject) { return new Promise(function(resolve, reject) {
db.any("select pages.cid, pages.pid, pages.title, company.company_name, '/export/' || pages.pid::text || '.html' as fullpath from pages join company on company.cid = pages.cid;") db.any(
"select pages.cid, pages.pid, pages.title, company.company_name, '/export/' || pages.pid::text || '.html' as fullpath from pages join company on company.cid = pages.cid;")
.then((d) => { .then((d) => {
return resolve(d); return resolve(d);
}) })
.catch((err)=> { .catch((err)=> {
console.log('+getPageList failed'); console.log('+getPageList failed');
console.log(err); console.log(err);
return reject(err); return reject(err);
}); });
}); });
}; };
module.getFullPageList = function() { module.getFullPageList = function() {
return new Promise(function(resolve, reject) { return new Promise(function(resolve, reject) {
db.any("select * from pages;") db.any("select * from pages;")
.then((d) => { .then((d) => {
let rArray = []; let rArray = [];
for (var l = 0;l < d.length;l++) { for (var l = 0; l < d.length; l++) {
let attributeObj = $U.newObjectFrom(d[l],['id','cid','vid','pid','content','title']); let attributeObj = $U.newObjectFrom(d[l],
attributeObj = $U.populateObject(d[l].data,attributeObj); ['id', 'cid', 'vid', 'pid', 'content', 'title']);
attributeObj = $U.populateObject(d[l].data, attributeObj);
let newObj = {"id":attributeObj.id, "type":"page","attributes":attributeObj}; let newObj = {
"id": attributeObj.id,
// { data: [ { "id": "56b7ecbc1ef21172377d6159", "type": "guest", "attributes": { "name":"Ray","message":"First ever guest post entry" } }, ... ] } "type": "page",
"attributes": attributeObj
};
// { data: [ { "id": "56b7ecbc1ef21172377d6159", "type": "guest", "attributes": { "name":"Ray","message":"First ever guest post entry" } }, ... ] }
rArray.push(newObj); rArray.push(newObj);
} }
return resolve(rArray); return resolve(rArray);
})
}) .catch((err)=> {
.catch((err)=> { console.log('+getPageList failed');
console.log('+getPageList failed'); console.log(err);
console.log(err); return reject(err);
return reject(err); });
}); });
}); };
};
module.sqlInsertPage = function(data) { module.sqlInsertPage = function(data) {
return new Promise(function(resolve, reject) { return new Promise(function(resolve, reject) {
db.func('upsert_page',data) db.func('upsert_page', data)
.then((d)=> { .then((d)=> {
console.log(d); console.log(d);
console.log('+sqlInsertPage OK'); console.log('+sqlInsertPage OK');
return resolve('ok'); return resolve('ok');
}) })
.catch((err)=> { .catch((err)=> {
console.log('+sqlInsertPage failed'); console.log('+sqlInsertPage failed');
console.log(err); console.log(err);
return reject(err); return reject(err);
}); });
}); });
}; };
module.addNewPage = function(data) { module.addNewPage = function(data) {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
let _data, _jsonData; let _data, _jsonData;
@ -91,22 +113,41 @@ module.exports = function(db) {
_data.pid = newId(); _data.pid = newId();
} }
_jsonData = $U.newObjectFrom(_data, ['title','image-url','link1-text','link1-url','link2-text','link2-url','link3-text','link3-url','link4-text','link4-url']); _jsonData = $U.newObjectFrom(_data,
[
'title',
'image-url',
'link1-text',
'link1-url',
'link2-text',
'link2-url',
'link3-text',
'link3-url',
'link4-text',
'link4-url'
]);
const sqlData = [_data.cid, _data.vid, _data.pid, _data.content, _data.title, JSON.stringify(_jsonData)]; const sqlData = [
_data.cid,
_data.vid,
_data.pid,
_data.content,
_data.title,
JSON.stringify(_jsonData)
];
console.log(sqlData); console.log(sqlData);
this.sqlInsertPage(sqlData) this.sqlInsertPage(sqlData)
.then(function(d) { .then(function(d) {
console.log('Inserted'); console.log('Inserted');
console.log(d); console.log(d);
data.attributes = _data; data.attributes = _data;
return resolve(data); return resolve(data);
}) })
.catch(function(err) { .catch(function(err) {
console.log('Failed to insert'); console.log('Failed to insert');
return reject(err); return reject(err);
}); });
}); });
}; };