김준서

Add MovieInfo method

1 +var express = require('express');
2 +const request = require('request');
3 +const TARGET_URL = 'https://api.line.me/v2/bot/message/reply'
4 +const TOKEN = 'ejLSECVgPBYNuEumq2Nw0w9ibDBoK9ixMnOp4jk41cLqHU5+vL1s5q7L4Ko7QcEiSCq1eJc1dPzG5P7HbbOKx490Oe6S1qZ7ob3YiTyfNN1NuOTm9jNYW22ctklbb8tFlDIDgSZbwz48jvQmAbdY9QdB04t89/1O/w1cDnyilFU='
5 +const KOFIC_URL = 'http://www.kobis.or.kr/kobisopenapi/webservice/rest/movie/searchMovieInfo.json'
6 +const KOFIC_KEY = 'fc36c6b83d1b3f06d8dc861b7e22787b'
7 +
8 +const fs = require('fs');
9 +const path = require('path');
10 +const HTTPS = require('https');
11 +const domain = "2018102181.osschatbot2022.tk"
12 +const sslport = 23023;
13 +const bodyParser = require('body-parser');
14 +var app = express();
15 +var translang = 'en';
16 +app.use(bodyParser.json());
17 +app.post('/hook', function (req, res) {
18 +
19 + var eventObj = req.body.events[0];
20 + var source = eventObj.source;
21 + var message = eventObj.message;
22 +
23 + // request log
24 + console.log('======================', new Date() ,'======================');
25 + console.log('[request]', req.body);
26 + console.log('[request source] ', eventObj.source);
27 + console.log('[request message]', eventObj.message);
28 +
29 + MovieInfo(eventObj.replyToken, eventObj.message.text);
30 +
31 +
32 + res.sendStatus(200);
33 +});
34 +
35 +function MovieInfo(replyToken, message) {
36 +
37 + request.get(
38 + {
39 + url: KOFIC_URL+`?key=${KOFIC_KEY}&movieCd=${message}`,
40 + json:true
41 + },(error, response, body) => {
42 + if(!error && response.statusCode == 200) {
43 + console.log(body.movieInfoResult);
44 + var MovieInfo = body.movieInfoResult.movieInfo;
45 + request.post(
46 + {
47 + url: TARGET_URL,
48 + headers: {
49 + 'Authorization': `Bearer ${TOKEN}`
50 + },
51 + json: {
52 + "replyToken":replyToken,
53 + "messages":[
54 + {
55 + "type":"text",
56 + "text":`영화명: ${MovieInfo.movieNm}\n개봉날짜: ${MovieInfo.prdtYear}\n상영시간: ${MovieInfo.showTm}분\n장르: ${MovieInfo.genres[0].genreNm}\n감독: ${MovieInfo.directors[0].peopleNm}\n출연배우: ${MovieInfo.actors[0].peopleNm},${MovieInfo.actors[1].peopleNm},${MovieInfo.actors[2].peopleNm},${MovieInfo.actors[3].peopleNm}`
57 + }
58 + ]
59 + }
60 + },(error, response, body) => {
61 + console.log(body)
62 + });
63 + }
64 + });
65 +
66 +}
67 +
68 +try {
69 + const option = {
70 + ca: fs.readFileSync('/etc/letsencrypt/live/' + domain +'/fullchain.pem'),
71 + key: fs.readFileSync(path.resolve(process.cwd(), '/etc/letsencrypt/live/' + domain +'/privkey.pem'), 'utf8').toString(),
72 + cert: fs.readFileSync(path.resolve(process.cwd(), '/etc/letsencrypt/live/' + domain +'/cert.pem'), 'utf8').toString(),
73 + };
74 +
75 + HTTPS.createServer(option, app).listen(sslport, () => {
76 + console.log(`[HTTPS] Server is started on port ${sslport}`);
77 + });
78 + } catch (error) {
79 + console.log('[HTTPS] HTTPS 오류가 발생하였습니다. HTTPS 서버는 실행되지 않습니다.');
80 + console.log(error);
81 + }
82 +
...\ No newline at end of file ...\ No newline at end of file
This diff is collapsed. Click to expand it.
1 +{
2 + "name": "trans",
3 + "version": "1.0.0",
4 + "description": "",
5 + "main": "app.js",
6 + "scripts": {
7 + "test": "echo \"Error: no test specified\" && exit 1"
8 + },
9 + "author": "",
10 + "license": "ISC",
11 + "dependencies": {
12 + "express": "^4.17.1",
13 + "request": "^2.88.2"
14 + }
15 +}