-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathuser.js
118 lines (102 loc) · 4.24 KB
/
user.js
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
'use strict';
const request = require('request');
const config = require('./config');
const pg = require('pg');
pg.defaults.ssl = true;
module.exports = {
addUser: function(callback, userId) {
request({
uri: 'https://graph.facebook.com/v2.7/' + userId,
qs: {
access_token: config.FB_PAGE_TOKEN
}
}, function (error, response, body) {
if (!error && response.statusCode == 200) {
var user = JSON.parse(body);
if (user.first_name.length > 0) {
var pool = new pg.Pool(config.PG_CONFIG);
pool.connect(function(err, client, done) {
if (err) {
return console.error('Error acquiring client', err.stack);
}
var rows = [];
client.query(`SELECT id FROM users WHERE fb_id='${userId}' LIMIT 1`,
function(err, result) {
if (err) {
console.log('Query error: ' + err);
} else {
console.log('rows: ' + result.rows.length);
if (result.rows.length === 0) {
let sql = 'INSERT INTO users (fb_id, first_name, last_name, profile_pic, ' +
'locale, timezone, gender) VALUES ($1, $2, $3, $4, $5, $6, $7)';
console.log('sql: ' + sql);
client.query(sql,
[
userId,
user.first_name,
user.last_name,
user.profile_pic,
user.locale,
user.timezone,
user.gender
]);
}
}
});
callback(user);
});
pool.end();
} else {
console.log("Cannot get data for fb user with id",
userId);
}
} else {
console.error(response.error);
}
});
},
readAllUsers: function(callback, newstype) {
var pool = new pg.Pool(config.PG_CONFIG);
pool.connect(function(err, client, done) {
if (err) {
return console.error('Error acquiring client', err.stack);
}
client
.query(
'SELECT fb_id, first_name, last_name FROM users WHERE newsletter=$1',
[newstype],
function(err, result) {
if (err) {
console.log(err);
callback([]);
} else {
console.log('rows');
console.log(result.rows);
callback(result.rows);
};
});
});
pool.end();
},
newsletterSettings: function(callback, setting, userId) {
var pool = new pg.Pool(config.PG_CONFIG);
pool.connect(function(err, client, done) {
if (err) {
return console.error('Error acquiring client', err.stack);
}
client
.query(
'UPDATE users SET newsletter=$1 WHERE fb_id=$2',
[setting, userId],
function(err, result) {
if (err) {
console.log(err);
callback(false);
} else {
callback(true);
};
});
});
pool.end();
}
}