Showing
1 changed file
with
220 additions
and
0 deletions
concert.js
0 → 100644
1 | +var createServer = require("auto-sni"); | ||
2 | +var express = require("express"); | ||
3 | +var app = express(); | ||
4 | +const line = require('@line/bot-sdk'); | ||
5 | +var request = require('request'); | ||
6 | +var https=require('https'); | ||
7 | +var http=require('http'); | ||
8 | + | ||
9 | +const lex = require('greenlock-express').create({ | ||
10 | + version: 'draft-11', // 버전2 | ||
11 | + store: require('greenlock-store-fs'), | ||
12 | + configDir: '/etc/letsencrypt', // 또는 ~/letsencrypt/etc | ||
13 | + approveDomains: (opts, certs, cb) => { | ||
14 | + if (certs) { | ||
15 | + opts.domains = ['oss.chatbot.bu.to', 'oss.chatbot.bu.to']; | ||
16 | + } else { | ||
17 | + opts.email = 'sweun1@naver.com'; | ||
18 | + opts.agreeTos = true; | ||
19 | + } | ||
20 | + cb(null, { options: opts, certs }); | ||
21 | + }, | ||
22 | + renewWithin: 81 * 24 * 60 * 60 * 1000, | ||
23 | + renewBy: 80 * 24 * 60 * 60 * 1000, | ||
24 | +});//papago api | ||
25 | + | ||
26 | + | ||
27 | +https.createServer(lex.httpsOptions, lex.middleware(app)).listen((process.env.SSL_PORT || 443),()=>{ | ||
28 | + console.log("server on 443"); | ||
29 | +}); | ||
30 | +http.createServer(lex.middleware(require('redirect-https')())).listen(process.env.PORT || 80,()=>{ | ||
31 | + console.log("server on 80"); | ||
32 | +}); | ||
33 | + | ||
34 | +//번역 api_url | ||
35 | +var translate_api_url = 'https://openapi.naver.com/v1/papago/n2mt'; | ||
36 | + | ||
37 | +//언어감지 api_url | ||
38 | +var languagedetect_api_url = 'https://openapi.naver.com/v1/papago/detectLangs' | ||
39 | + | ||
40 | +// Naver Auth Key | ||
41 | +//새로 발급받은 naver papago api id, pw 입력 | ||
42 | +var client_id = 'bIYcswH22VlQqT8OkkLm'; | ||
43 | +var client_secret = 'qLaERoks0u'; | ||
44 | + | ||
45 | +const config = { | ||
46 | + channelAccessToken: 'dWno95uZ/FLPM5BoTUIM1kPenQ+UsEHYSWphPWcOxyjS7eylg6jhocxvJCeV8YumuVvYf+3bE/696ZSkOPJitxhXbXDe+1p2WoyCbHzD8KxxF1EKo6zvHfnhsIA8kZS93lNzUTQr1FVWaMmRKl7NzwdB04t89/1O/w1cDnyilFU=', | ||
47 | + channelSecret: '75a2fd95ec26d716cac6fcdd520b9b9c' | ||
48 | + | ||
49 | +}; | ||
50 | + | ||
51 | +// create LINE SDK client | ||
52 | +const client = new line.Client(config); | ||
53 | +// create Express app | ||
54 | +// about Express itself: https://expressjs.com/ | ||
55 | + | ||
56 | +// register a webhook handler with middleware | ||
57 | +// about the middleware, please refer to doc | ||
58 | + | ||
59 | +var cheerio = require('cheerio'); | ||
60 | +var data = require('./event.json'); | ||
61 | +//json 불러오기 | ||
62 | + | ||
63 | +var data_list = data["DATA"] | ||
64 | +var concert_list = []; | ||
65 | + | ||
66 | +for(var i = 0; i < data_list.length; i++){ | ||
67 | + if (data_list[i].codename=="콘서트"){ | ||
68 | + concert_list.push(data_list[i].title); | ||
69 | + } | ||
70 | + } | ||
71 | + | ||
72 | +for(var i = 0; i < concert_list.length; i++){ | ||
73 | + console.log(i+1,'. ',concert_list[i],'\n'); | ||
74 | + } | ||
75 | +//콘서트 목록 만들기 | ||
76 | + | ||
77 | +app.post('/webhook', line.middleware(config), (req, res) => { | ||
78 | +console.log(res.statusCode); | ||
79 | + Promise | ||
80 | + .all(req.body.events.map(handleEvent)) | ||
81 | + .then((result) => res.json(result)) | ||
82 | + .catch((err)=>{console.log(err); | ||
83 | + }) | ||
84 | +}); | ||
85 | + | ||
86 | +// event handler | ||
87 | +function handleEvent(event) { | ||
88 | + console.log(event.message); | ||
89 | + if (event.type !== 'message' || event.message.type !== 'text') { | ||
90 | + // ignore non-text-message event | ||
91 | + return Promise.resolve(null); | ||
92 | + } | ||
93 | + else if(event.message.text.substring(0,6)=='콘서트 보기'){ | ||
94 | + | ||
95 | + return new Promise(function(resolve, reject) | ||
96 | + { | ||
97 | + var showlist = { type: 'text', text:''}; | ||
98 | + for(var i = 0; i < concert_list.length; i++) | ||
99 | + { | ||
100 | + showlist.text+=i+1 + ". " + concert_list[i] + "\n"; | ||
101 | + } | ||
102 | + console.log(showlist.text); | ||
103 | + var result={type:'text',text:showlist.text} | ||
104 | + | ||
105 | + client.replyMessage(event.replyToken, result).then(resolve).catch(reject); | ||
106 | + }); | ||
107 | + | ||
108 | + } | ||
109 | + else if(isNaN(event.message.text)){ | ||
110 | + | ||
111 | + var selectnum = (event.message.text*1); | ||
112 | + | ||
113 | + if(selectnum >=0 || selectnum <=27){ | ||
114 | + result.text = '목록에 존재하지 않는 콘서트입니다.'; | ||
115 | + client.replyMessage(event.replyToken, result).then(resolve).catch(reject); | ||
116 | + } | ||
117 | + | ||
118 | + return new Promise(function(resolve, reject){ | ||
119 | + var concert_name = concert_list[selectnum-1]; | ||
120 | + var $ = cheerio.load(concert_name); | ||
121 | + var keyword = $.text(); | ||
122 | + console.log(keyword); | ||
123 | + | ||
124 | + var options = {method: 'GET', | ||
125 | + url: 'https://www.googleapis.com/youtube/v3/search', | ||
126 | + qs: { key: 'AIzaSyB4b-n8SSv73CLDKvFigpLPYA6yWG2JQ9A', | ||
127 | + part: 'id', | ||
128 | + maxResults: '1', | ||
129 | + order: 'relevance', | ||
130 | + q: keyword, | ||
131 | + type: 'video'} | ||
132 | + }; | ||
133 | + | ||
134 | + var videourl = { type: 'url', label: '관련 영상', url:''}; | ||
135 | + | ||
136 | + request(options, function(error,result,body){ | ||
137 | + if(error) throw new Error(error); | ||
138 | + | ||
139 | + var temp = body.split(':'); | ||
140 | + videourl.url += "https://www.youtube.com/watch?v=" + temp1[13].substr(2,11); | ||
141 | + }); | ||
142 | + | ||
143 | + console.log(videourl.url); | ||
144 | + | ||
145 | + client.replyMessage(event.replyToken, videourl).then(resolve).catch(reject); | ||
146 | + })}; | ||
147 | + | ||
148 | + app.post('/webhook', line.middleware(config), (req, res) => { | ||
149 | + console.log(res.statusCode); | ||
150 | + Promise | ||
151 | + .all(req.body.events.map(handleEvent2)) | ||
152 | + .then((result) => res.json(result)) | ||
153 | + .catch((err)=>{console.log(err); | ||
154 | + }) | ||
155 | + }); | ||
156 | + | ||
157 | + return new Promise(function(resolve, reject) { | ||
158 | + //언어 감지 option | ||
159 | + var detect_options = { | ||
160 | + url : languagedetect_api_url, | ||
161 | + form : {'query': event.message.text}, | ||
162 | + headers: {'X-Naver-Client-Id': client_id, 'X-Naver-Client-Secret': client_secret} | ||
163 | + }; | ||
164 | + //papago 언어 감지 | ||
165 | + | ||
166 | + request.post(detect_options,async (error,response,body)=>{ | ||
167 | + console.log(response.statusCode); | ||
168 | + if(!error && response.statusCode == 200){ | ||
169 | + var detect_body = JSON.parse(response.body); | ||
170 | + var source = ''; | ||
171 | + var target = ''; | ||
172 | + var result = { type: 'text', text:''}; | ||
173 | + | ||
174 | + //언어 감지가 제대로 됐는지 확인 | ||
175 | + console.log(detect_body.langCode); | ||
176 | + | ||
177 | + | ||
178 | + //번역은 한국어->영어 / 영어->한국어만 지원 | ||
179 | + if(detect_body.langCode == 'ko'||detect_body.langCode == 'en'){ | ||
180 | + source = detect_body.langCode == 'ko' ? 'ko':'en'; | ||
181 | + target = source == 'ko' ? 'en':'ko'; | ||
182 | + //papago 번역 option | ||
183 | + var options = { | ||
184 | + url: translate_api_url, | ||
185 | + // 한국어(source : ko), 영어(target: en), 카톡에서 받는 메시지(text) | ||
186 | + form: {'source':source, 'target':target, 'text':event.message.text}, | ||
187 | + headers: {'X-Naver-Client-Id': client_id, 'X-Naver-Client-Secret': client_secret,"Content-Type": "application/x-www-form-urlencoded"} | ||
188 | + }; | ||
189 | + | ||
190 | + // Naver Post API | ||
191 | + await request.post(options, function(error, response, body){ | ||
192 | + // Translate API Sucess | ||
193 | + if(!error && response.statusCode == 200){ | ||
194 | + // JSON | ||
195 | + var objBody = JSON.parse(response.body); | ||
196 | + // Message 잘 찍히는지 확인 | ||
197 | + | ||
198 | + result.text = objBody.message.result.translatedText; | ||
199 | + console.log(result); | ||
200 | + //번역된 문장 보내기 | ||
201 | + client.replyMessage(event.replyToken,result).then(resolve); | ||
202 | + } | ||
203 | + }); | ||
204 | + } | ||
205 | + // 메시지의 언어가 영어 또는 한국어가 아닐 경우 | ||
206 | + else{ | ||
207 | + result.text = '언어를 감지할 수 없습니다. \n 번역 언어는 한글 또는 영어만 가능합니다.'; | ||
208 | + client.replyMessage(event.replyToken,result).then(resolve); | ||
209 | + } | ||
210 | + | ||
211 | + } | ||
212 | + else{ | ||
213 | + console.log("status code is not 200"); | ||
214 | + } | ||
215 | + | ||
216 | + }); | ||
217 | + | ||
218 | + }); | ||
219 | + } | ||
220 | + |
-
Please register or login to post a comment