Showing
7 changed files
with
263 additions
and
18 deletions
This diff could not be displayed because it is too large.
... | @@ -29,7 +29,7 @@ exports.handlePostback = (sender_psid, received_postback) => { | ... | @@ -29,7 +29,7 @@ exports.handlePostback = (sender_psid, received_postback) => { |
29 | }else if(payload.substr(0,14) ==='CHOICE_BY_HELP'){ | 29 | }else if(payload.substr(0,14) ==='CHOICE_BY_HELP'){ |
30 | handlePostback_help(sender_psid, recieved_postback); | 30 | handlePostback_help(sender_psid, recieved_postback); |
31 | }else if(payload.substr(0,8) === 'MoreRate'){ | 31 | }else if(payload.substr(0,8) === 'MoreRate'){ |
32 | - response = template.moreRageTemplate(received_postback); | 32 | + response = template.moreRateTemplate(received_postback); |
33 | callSendAPI(sender_psid, response); | 33 | callSendAPI(sender_psid, response); |
34 | } | 34 | } |
35 | } | 35 | } | ... | ... |
models.js
deleted
100644 → 0
File mode changed
... | @@ -73,6 +73,11 @@ | ... | @@ -73,6 +73,11 @@ |
73 | "tweetnacl": "^0.14.3" | 73 | "tweetnacl": "^0.14.3" |
74 | } | 74 | } |
75 | }, | 75 | }, |
76 | + "bignumber.js": { | ||
77 | + "version": "7.2.1", | ||
78 | + "resolved": "https://registry.npmjs.org/bignumber.js/-/bignumber.js-7.2.1.tgz", | ||
79 | + "integrity": "sha512-S4XzBk5sMB+Rcb/LNcpzXr57VRTxgAvaAEDAl1AwRx27j00hT84O6OkteE7u8UB3NuaaygCRrEpqox4uDOrbdQ==" | ||
80 | + }, | ||
76 | "bluebird": { | 81 | "bluebird": { |
77 | "version": "3.5.1", | 82 | "version": "3.5.1", |
78 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", | 83 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", |
... | @@ -369,6 +374,11 @@ | ... | @@ -369,6 +374,11 @@ |
369 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", | 374 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", |
370 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" | 375 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" |
371 | }, | 376 | }, |
377 | + "isarray": { | ||
378 | + "version": "1.0.0", | ||
379 | + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", | ||
380 | + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" | ||
381 | + }, | ||
372 | "isstream": { | 382 | "isstream": { |
373 | "version": "0.1.2", | 383 | "version": "0.1.2", |
374 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", | 384 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", |
... | @@ -538,6 +548,17 @@ | ... | @@ -538,6 +548,17 @@ |
538 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", | 548 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", |
539 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" | 549 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" |
540 | }, | 550 | }, |
551 | + "mysql": { | ||
552 | + "version": "2.17.1", | ||
553 | + "resolved": "https://registry.npmjs.org/mysql/-/mysql-2.17.1.tgz", | ||
554 | + "integrity": "sha512-7vMqHQ673SAk5C8fOzTG2LpPcf3bNt0oL3sFpxPEEFp1mdlDcrLK0On7z8ZYKaaHrHwNcQ/MTUz7/oobZ2OyyA==", | ||
555 | + "requires": { | ||
556 | + "bignumber.js": "7.2.1", | ||
557 | + "readable-stream": "2.3.6", | ||
558 | + "safe-buffer": "5.1.2", | ||
559 | + "sqlstring": "2.3.1" | ||
560 | + } | ||
561 | + }, | ||
541 | "negotiator": { | 562 | "negotiator": { |
542 | "version": "0.6.2", | 563 | "version": "0.6.2", |
543 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", | 564 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", |
... | @@ -571,6 +592,11 @@ | ... | @@ -571,6 +592,11 @@ |
571 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", | 592 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", |
572 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" | 593 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" |
573 | }, | 594 | }, |
595 | + "process-nextick-args": { | ||
596 | + "version": "2.0.0", | ||
597 | + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", | ||
598 | + "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==" | ||
599 | + }, | ||
574 | "proxy-addr": { | 600 | "proxy-addr": { |
575 | "version": "2.0.5", | 601 | "version": "2.0.5", |
576 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.5.tgz", | 602 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.5.tgz", |
... | @@ -611,6 +637,20 @@ | ... | @@ -611,6 +637,20 @@ |
611 | "unpipe": "1.0.0" | 637 | "unpipe": "1.0.0" |
612 | } | 638 | } |
613 | }, | 639 | }, |
640 | + "readable-stream": { | ||
641 | + "version": "2.3.6", | ||
642 | + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", | ||
643 | + "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", | ||
644 | + "requires": { | ||
645 | + "core-util-is": "~1.0.0", | ||
646 | + "inherits": "~2.0.3", | ||
647 | + "isarray": "~1.0.0", | ||
648 | + "process-nextick-args": "~2.0.0", | ||
649 | + "safe-buffer": "~5.1.1", | ||
650 | + "string_decoder": "~1.1.1", | ||
651 | + "util-deprecate": "~1.0.1" | ||
652 | + } | ||
653 | + }, | ||
614 | "regexp-clone": { | 654 | "regexp-clone": { |
615 | "version": "0.0.1", | 655 | "version": "0.0.1", |
616 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-0.0.1.tgz", | 656 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-0.0.1.tgz", |
... | @@ -750,6 +790,11 @@ | ... | @@ -750,6 +790,11 @@ |
750 | "memory-pager": "^1.0.2" | 790 | "memory-pager": "^1.0.2" |
751 | } | 791 | } |
752 | }, | 792 | }, |
793 | + "sqlstring": { | ||
794 | + "version": "2.3.1", | ||
795 | + "resolved": "https://registry.npmjs.org/sqlstring/-/sqlstring-2.3.1.tgz", | ||
796 | + "integrity": "sha1-R1OT/56RR5rqYtyvDKPRSYOn+0A=" | ||
797 | + }, | ||
753 | "sshpk": { | 798 | "sshpk": { |
754 | "version": "1.16.1", | 799 | "version": "1.16.1", |
755 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", | 800 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", |
... | @@ -771,6 +816,14 @@ | ... | @@ -771,6 +816,14 @@ |
771 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", | 816 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", |
772 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" | 817 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" |
773 | }, | 818 | }, |
819 | + "string_decoder": { | ||
820 | + "version": "1.1.1", | ||
821 | + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", | ||
822 | + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", | ||
823 | + "requires": { | ||
824 | + "safe-buffer": "~5.1.0" | ||
825 | + } | ||
826 | + }, | ||
774 | "toidentifier": { | 827 | "toidentifier": { |
775 | "version": "1.0.0", | 828 | "version": "1.0.0", |
776 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", | 829 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", |
... | @@ -827,6 +880,11 @@ | ... | @@ -827,6 +880,11 @@ |
827 | "punycode": "^2.1.0" | 880 | "punycode": "^2.1.0" |
828 | } | 881 | } |
829 | }, | 882 | }, |
883 | + "util-deprecate": { | ||
884 | + "version": "1.0.2", | ||
885 | + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", | ||
886 | + "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" | ||
887 | + }, | ||
830 | "utils-merge": { | 888 | "utils-merge": { |
831 | "version": "1.0.1", | 889 | "version": "1.0.1", |
832 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", | 890 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", | ... | ... |
1 | -const db = require('./db.js'); | 1 | +const db = require('./db'); |
2 | 2 | ||
3 | let greetingText = "안녕하세요! 컴공/소융 강의평가 봇이에요. 아래에 버튼 3개를 눌러주세요."; // 인사말 | 3 | let greetingText = "안녕하세요! 컴공/소융 강의평가 봇이에요. 아래에 버튼 3개를 눌러주세요."; // 인사말 |
4 | let greetingTitle = ["교수명으로 검색", "강의명으로 검색", "HELP"]; | 4 | let greetingTitle = ["교수명으로 검색", "강의명으로 검색", "HELP"]; |
... | @@ -54,30 +54,220 @@ exports.getProfNameTemplate = (received) => { | ... | @@ -54,30 +54,220 @@ exports.getProfNameTemplate = (received) => { |
54 | } | 54 | } |
55 | 55 | ||
56 | exports.getLectNameTemplate = (received) => { | 56 | exports.getLectNameTemplate = (received) => { |
57 | -//메세지 | 57 | + return { |
58 | - return{text: "성공"} | 58 | + "attachment":{ |
59 | - | 59 | + "type":"template", |
60 | - //텍스트 메세지를 필드로 디비에서 수업/교수명 찾아서 목록 제공 | 60 | + "payload":{ |
61 | - | 61 | + "template_type":"button", |
62 | + "text": "강의명을 입력하세요.", | ||
63 | + "buttons":[ | ||
64 | + { | ||
65 | + "type":"postback", | ||
66 | + "title":"처음으로", | ||
67 | + "payload":'Greeting' | ||
68 | + } | ||
69 | + ] | ||
70 | + } | ||
71 | + } | ||
72 | + } | ||
62 | } | 73 | } |
63 | 74 | ||
64 | //stat_1 | 75 | //stat_1 |
65 | exports.choiceLectProfTemplate = (received) => { | 76 | exports.choiceLectProfTemplate = (received) => { |
66 | -//버튼 | 77 | + let message = received.text; |
78 | + db.query('SELECT * FROM reviews WHERE lecturename LIKE ? OR proname LIKE ?', [message,message], function(error,results){ | ||
79 | + if (err){ | ||
80 | + console.log(err); | ||
81 | + res.render('error'); | ||
82 | + } | ||
83 | + if(results==0){ | ||
84 | + return {text: "검색 결과가 없습니다. 검색어를 다시 입력해주세요."} | ||
85 | + }else if(results.length<=2){ | ||
86 | + return LectProfList(results,0,results.length,false,'0',message); | ||
87 | + }else if(results.length>2){ | ||
88 | + return LectProfList(results,0,2,true,'1',message); | ||
89 | + } | ||
90 | + }); | ||
91 | +} | ||
92 | + | ||
93 | +const LectProfList = (results,start,length,ismore,morecount,message) => { | ||
94 | + if(length==1){ | ||
95 | + return { | ||
96 | + "attachment":{ | ||
97 | + "type":"template", | ||
98 | + "payload":{ | ||
99 | + "template_type":"button", | ||
100 | + "text": "검색 결과입니다. 평가를 조회할 강의를 선택하세요.", | ||
101 | + "buttons":[ | ||
102 | + { | ||
103 | + "type":"postback", | ||
104 | + "title":results[start].lecturename+results[start].proname, | ||
105 | + "payload":'CHOICE_BY_PROFstat_3'+results[start].idreviews | ||
106 | + } | ||
107 | + ] | ||
108 | + } | ||
109 | + } | ||
110 | + } | ||
111 | + }else if((length == 2)&&(!ismore)){ | ||
112 | + return { | ||
113 | + "attachment":{ | ||
114 | + "type":"template", | ||
115 | + "payload":{ | ||
116 | + "template_type":"button", | ||
117 | + "text": "검색 결과입니다. 평가를 조회할 강의를 선택하세요.", | ||
118 | + "buttons":[ | ||
119 | + { | ||
120 | + "type":"postback", | ||
121 | + "title":results[start].lecturename+results[start].proname, | ||
122 | + "payload":'CHOICE_BY_PROFstat_3'+results[start].idreviews | ||
123 | + }, | ||
124 | + { | ||
125 | + "type":"postback", | ||
126 | + "title":results[start+1].lecturename+results[start+1].proname, | ||
127 | + "payload":'CHOICE_BY_PROFstat_3'+results[start+1].idreviews | ||
128 | + } | ||
129 | + ] | ||
130 | + } | ||
131 | + } | ||
132 | + } | ||
133 | + }else if((length == 2)&&(ismore)){ | ||
134 | + return { | ||
135 | + "attachment":{ | ||
136 | + "type":"template", | ||
137 | + "payload":{ | ||
138 | + "template_type":"button", | ||
139 | + "text": "검색 결과입니다. 평가를 조회할 강의를 선택하세요. 원하는 강의가 없다면 [더보기]를 눌러주세요.", | ||
140 | + "buttons":[ | ||
141 | + { | ||
142 | + "type":"postback", | ||
143 | + "title":results[start].lecturename+results[start].proname, | ||
144 | + "payload":'CHOICE_BY_PROFstat_3'+results[start].idreviews | ||
145 | + }, | ||
146 | + { | ||
147 | + "type":"postback", | ||
148 | + "title":results[start+1].lecturename+results[start+1].proname, | ||
149 | + "payload":'CHOICE_BY_PROFstat_3'+results[start+1].idreviews | ||
150 | + }, | ||
151 | + { | ||
152 | + "type":"postback", | ||
153 | + "title":"더보기", | ||
154 | + "payload":'CHOICE_BY_PROFstat_2'+message+'/'+morecount | ||
155 | + } | ||
156 | + ] | ||
157 | + } | ||
158 | + } | ||
159 | + } | ||
160 | + } | ||
161 | + | ||
67 | } | 162 | } |
68 | 163 | ||
69 | //stat_2 | 164 | //stat_2 |
70 | exports.moreProfTemplate = (received) => { | 165 | exports.moreProfTemplate = (received) => { |
71 | -//버튼 | 166 | + let ms=received.payload.substr(20).split('/'); |
167 | + let more=1*(ms[0]); //to Number | ||
168 | + let message=ms[1]; | ||
169 | + | ||
170 | + db.query('SELECT * FROM reviews WHERE lecturename LIKE ? OR proname LIKE ?', [message,message], function(error,results){ | ||
171 | + if (err){ | ||
172 | + console.log(err); | ||
173 | + res.render('error'); | ||
174 | + } | ||
175 | + if((results.length-2*(more+1))<=0){ | ||
176 | + return LectProfList(results,2*more,results.length-2*n,false,'0',message); | ||
177 | + }else{ | ||
178 | + return LectProfList(results,2*more,2,true,""+(more+1),message); | ||
179 | + } | ||
180 | + }); | ||
72 | } | 181 | } |
73 | 182 | ||
74 | exports.moreLectTemplate= (received) => { | 183 | exports.moreLectTemplate= (received) => { |
75 | -//버튼 | 184 | +let ms=received.payload.substr(20).split('/'); |
185 | + let more=1*(ms[0]); | ||
186 | + let message=ms[1]; | ||
187 | + | ||
188 | + db.query('SELECT * FROM reviews WHERE lecturename LIKE ? OR proname LIKE ?', [message,message], function(error,results){ | ||
189 | + if (err){ | ||
190 | + console.log(err); | ||
191 | + res.render('error'); | ||
192 | + } | ||
193 | + if((results.length-2*(more+1))<=0){ | ||
194 | + return LectProfList(results,2*more,results.length-2*n,false,'0',message); | ||
195 | + }else{ | ||
196 | + return LectProfList(results,2*more,2,true,""+(more+1),message); | ||
197 | + } | ||
198 | + }); | ||
76 | } | 199 | } |
77 | 200 | ||
78 | //stat_3 | 201 | //stat_3 |
79 | exports.rateTemplate= (received) => { | 202 | exports.rateTemplate= (received) => { |
80 | -//버튼 | 203 | + let id = received.payload.substr(20); |
204 | + | ||
205 | +db.query('SELECT * FROM reviews WHERE idreviews LIKE ?', [id], function(error,results){ | ||
206 | + if (err){ | ||
207 | + console.log(err); | ||
208 | + res.render('error'); | ||
209 | + } | ||
210 | + | ||
211 | + let proname=results[0].proname; | ||
212 | + let lecname=results[0].lecname; | ||
213 | + let reviews=results[0].review.split(','); | ||
214 | + let review=reviews[0]; | ||
215 | + let rate=results[0].avg_rate; | ||
216 | + let botsay=[]; | ||
217 | + let randNum=0; | ||
218 | + if(rate != 0){ | ||
219 | + Math.floor((Math.random() * (3-0+1))+0); | ||
220 | + } | ||
221 | + | ||
222 | + if(rate==0){ | ||
223 | + botsay=["신설 강좌거나 아직 강의평이 없어요!"]; | ||
224 | + }else if((rate>1)&&(rate<2.5)){ | ||
225 | + botsay=["음.. 말을 아낄게요.", "다시 생각해보시는게..","이전 단계로 돌아갈까요?","으응?"]; | ||
226 | + }else if((rate>=2.5)&&(rate<4.0)){ | ||
227 | + botsay=["무난무난","그럭저럭한 것 같아요.","안 들어서 나쁠거 없어요.","평범한 수업이네요"]; | ||
228 | + }else{ | ||
229 | + botsay=["무조건 들어요!","갓갓 교수님의 갓갓 수업","안 들으면 후회해요ㅠㅠ", "수강신청 1순위!"]; | ||
230 | + } | ||
231 | + | ||
232 | + return { | ||
233 | + "attachment":{ | ||
234 | + "type":"template", | ||
235 | + "payload":{ | ||
236 | + "template_type":"button", | ||
237 | + "text": proname+" 교수님의 강의 ["+lecname+"]의 강의평입니다.\n **평균 평점: "+rate+"\n **봇의 한줄평: "+botsay[randNum]+"\n **학우의 한줄평: "+reivew, | ||
238 | + "buttons":[ | ||
239 | + { | ||
240 | + "type":"postback", | ||
241 | + "title":"자세한 강의평 보기", | ||
242 | + "payload":'MoreRate'+id | ||
243 | + } | ||
244 | + ] | ||
245 | + } | ||
246 | + } | ||
247 | + } | ||
248 | + | ||
249 | + }); | ||
250 | +} | ||
251 | + | ||
252 | +exports.moreRateTemplate = (received) => { | ||
253 | + let id = received.payload.substr(8); | ||
254 | + let total_review=""; | ||
255 | + | ||
256 | + db.query('SELECT * FROM reviews WHERE idreviews LIKE ?', [id], function(error,results){ | ||
257 | + if (err){ | ||
258 | + console.log(err); | ||
259 | + res.render('error'); | ||
260 | + } | ||
261 | + | ||
262 | + let reviews=results[0].review.split(','); | ||
263 | + for(var review in reviews){ | ||
264 | + total_review+=review+"\n"; | ||
265 | + } | ||
266 | + | ||
267 | + return {text:total_review} | ||
268 | + }); | ||
269 | + //payload:MoreRate(강의식별번호) | ||
270 | + //포스트백 핸들 moreRateTemplate에서 해당 강의의 자세한 평 출력 | ||
81 | } | 271 | } |
82 | 272 | ||
83 | //payload === 'HELP' | 273 | //payload === 'HELP' |
... | @@ -118,7 +308,3 @@ return { | ... | @@ -118,7 +308,3 @@ return { |
118 | } | 308 | } |
119 | } | 309 | } |
120 | } | 310 | } |
121 | - | ||
122 | -exports.moreRageTemplate = (received) => { | ||
123 | - | ||
124 | -} | ||
... | \ No newline at end of file | ... | \ No newline at end of file | ... | ... |
-
Please register or login to post a comment