main.js
3.46 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
//=============================================================
var express = require('express');
const request = require('request');
const config = require('./config.json');
//=============================================================
const LINE_URL = 'https://api.line.me/v2/bot/message';
const TOKEN = config.TOKEN;
const KOFIC_URL = 'http://www.kobis.or.kr/kobisopenapi/webservice/rest';
const KOFIC_KEY = config.KOFIC_KEY;
//=============================================================
const fs = require('fs');
const path = require('path');
const HTTPS = require('https');
const domain = config.domain;
const sslport = 23023;
const bodyParser = require('body-parser');
var app = express();
app.use(bodyParser.json());
//=============================================================
var BoxOffice = require('./features/DailyBoxOfficeList.js');
var MovieList = require('./features/MovieList.js');
var MovieInfo = require('./features/MovieInfo.js');
var MovieReco = require('./features/MovieRecommend.js');
var Exception = require('./features/Exception.js');
//=============================================================
const user_id = config.USER_ID;
//=============================================================
// SHOW MENU
function ShowMenu(replyToken) {
request.post({
url: LINE_URL + '/reply',
headers: {
'Authorization': `Bearer ${TOKEN}`
},
json: {
"replyToken":replyToken,
"messages": [
{
"type": "text",
"text": "[0번 입력] : 메뉴 출력\n[1번 입력] : 최신영화 추천\n[2번 입력] : 장르별 영화 추천\n[3번 입력] : 영화 검색하기\n**영화코드 입력 : 영화 상세정보 조회"
}
]
}
}, (error, response, body) => {
console.log(body)
});
}
// RECEIVE MESSAGE
app.post('/hook', function (req, res) {
var eventObj = req.body.events[0];
Response(eventObj.replyToken, eventObj.message.text);
res.sendStatus(200);
});
var flag_2 = 0;
var flag_3 = 0;
// RESPONSE TO MESSAGE
function Response(replyToken, message) {
if (isNaN(message) === false && message.length === 8) {
MovieInfo.MovieInfo(replyToken, message);
}
else if (message == '0' || message == '0번') {
ShowMenu(replyToken);
}
else if (message == '1' || message == '1번') {
BoxOffice.ShowYesterdayRank(replyToken);
}
else if ((message == '2' || message == '2번') && flag_2 == 0) {
flag_2 = 1;
Exception.ShowGenre(replyToken);
}
else if ((message == '3' || message == '3번') && flag_3 == 0) {
flag_3 = 1;
Exception.ShowSearch(replyToken);
}
else if (flag_2 == 1) {
flag_2 = 0;
MovieReco.movieRecommend(replyToken, message);
}
else if (flag_3 == 1) {
flag_3 = 0;
MovieList.movielist(replyToken, message);
}
else {
Exception.SayIDontKnow(replyToken);
}
}
// ※ WARNING: DO NOT TOUCH THIS CODE SECTION ※
try {
const option = {
ca: fs.readFileSync('/etc/letsencrypt/live/' + domain + '/fullchain.pem'),
key: fs.readFileSync(path.resolve(process.cwd(), '/etc/letsencrypt/live/' + domain + '/privkey.pem'), 'utf8').toString(),
cert: fs.readFileSync(path.resolve(process.cwd(), '/etc/letsencrypt/live/' + domain + '/cert.pem'), 'utf8').toString(),
};
HTTPS.createServer(option, app).listen(sslport, () => {
console.log(`[HTTPS] Server is started on port ${sslport}`);
});
} catch (error) {
console.log('[HTTPS] HTTPS 오류가 발생하였습니다. HTTPS 서버는 실행되지 않습니다.');
console.log(error);
}