-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
114 lines (96 loc) · 2.84 KB
/
Copy pathserver.js
File metadata and controls
114 lines (96 loc) · 2.84 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
var express = require("express");
var app = express();
var cfenv = require("cfenv");
var bodyParser = require('body-parser')
// parse application/x-www-form-urlencoded
app.use(bodyParser.urlencoded({ extended: false }))
// parse application/json
app.use(bodyParser.json())
var mydb;
/* Endpoint to greet and add a new visitor to database.
* Send a POST request to localhost:3000/api/visitors with body
* {
* "name": "Bob"
* }
*/
app.post("/api/visitors", function (request, response) {
var userName = request.body.name;
var greeting = "Hello";
var now = new Date();
if (now.getHours() < 12) {
greeting = "Jolly good morning";
} else if (now.getHours() < 17) {
greeting = "Jolly good afternoon";
} else {
greeting = "Jolly good evening";
}
if(!mydb) {
console.log("No database.");
response.send(greeting + " " + userName + "!");
return;
}
// insert the username as a document
mydb.insert({ "name" : userName }, function(err, body, header) {
if (err) {
return console.log('[mydb.insert] ', err.message);
}
response.send(greeting + " " + userName + "! I added you to the database.");
});
});
/**
* Endpoint to get a JSON array of all the visitors in the database
* REST API example:
* <code>
* GET http://localhost:3000/api/visitors
* </code>
*
* Response:
* [ "Bob", "Jane" ]
* @return An array of all the visitor names
*/
app.get("/api/visitors", function (request, response) {
var names = [];
if(!mydb) {
response.json(names);
return;
}
mydb.list({ include_docs: true }, function(err, body) {
if (!err) {
body.rows.forEach(function(row) {
if(row.doc.name)
names.push(row.doc.name);
});
response.json(names);
}
});
});
// load local VCAP configuration and service credentials
var vcapLocal;
try {
vcapLocal = require('./vcap-local.json');
console.log("Loaded local VCAP", vcapLocal);
} catch (e) { }
const appEnvOpts = vcapLocal ? { vcap: vcapLocal} : {}
const appEnv = cfenv.getAppEnv(appEnvOpts);
if (appEnv.services['cloudantNoSQLDB']) {
// Load the Cloudant library.
var Cloudant = require('cloudant');
// Initialize database with credentials
var cloudant = Cloudant(appEnv.services['cloudantNoSQLDB'][0].credentials);
// Create a new "mydb" database.
cloudant.db.create('mydb', function(err, data) {
if(err) //If database already exists
console.log("err creating db. It might already exist.");
//console.log(err);
else
console.log("Created database.");
});
// Specify the database we are going to use (mydb)...
mydb = cloudant.db.use('mydb');
}
//serve static file (index.html, images, css)
app.use(express.static(__dirname + '/views'));
var port = process.env.PORT || 3000
app.listen(port, function() {
console.log("To view your app, open this link in your browser: http://localhost:" + port);
});