-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathweb.js
More file actions
118 lines (98 loc) · 2.64 KB
/
web.js
File metadata and controls
118 lines (98 loc) · 2.64 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
115
116
117
118
var express = require("express");
var pg = require('pg');
var freebase = require('freebase');
var app = express();
var db = process.env.DATABASE_URL || 'postgres://andres:martin@localhost:5432/postgres';
app.use(express.logger());
// Configuration
///////////////////////////////////////
app.configure(function() {
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(express.static(__dirname + '/public'));
app.use(app.router);
});
app.configure('development', function() {
app.use(express.errorHandler({
dumpExceptions: true,
showStack: true
}));
});
app.configure('production', function() {
app.use(express.errorHandler());
});
// Routes
///////////////////////////////////////
app.get('/install', function(request, response) {
pg.connect(db, function(err, client) {
var query = client.query('CREATE TABLE IF NOT EXISTS films (id SERIAL PRIMARY KEY, title VARCHAR(255) NOT NULL, description VARCHAR(255), image VARCHAR(255), year INTEGER, genre VARCHAR(255), length INTEGER, country VARCHAR(2))');
query.on('end', function() {
client.end();
});
});
response.render('install');
});
app.post('/film/create.json', function(request, response) {
pg.connect(db, function(err, client) {
if (request.body.title && request.body.description) {
client.query('INSERT INTO films (title, description) VALUES ($1, $2)', [request.body.title, request.body.description]);
response.json({
'success': true
});
} else {
response.json({
'success': false
});
}
});
});
app.post('/film/delete.json', function(request, response) {
pg.connect(db, function(err, client) {
if (request.body.id) {
client.query('DELETE FROM films WHERE id = $1', [request.body.id]);
response.json({
'success': true
});
} else {
response.json({
'success': false
});
}
});
});
app.post('/film/search.json', function(request, response) {
if (request.body.title) {
freebase.description(request.body.title, {
type: '/film/film'
}, function(result) {
response.json({
'success': true,
'data': result
});
});
} else {
response.json({
'success': false
});
}
});
app.get('/', function(request, response) {
pg.connect(db, function(err, client) {
var query = client.query('SELECT * FROM films', function(err, result) {
response.render('index', {
'films': result.rows
});
});
query.on('end', function() {
client.end();
});
});
});
// Start server
///////////////////////////////////////
var port = process.env.PORT || 5000;
app.listen(port, function() {
console.log("Listening on port " + port);
});