app.js 4.53 KB
var express = require('express');
const request = require('request');
const TARGET_URL = 'https://api.line.me/v2/bot/message/reply'
const TOKEN = 'rqZYufny8jqziXvpdrovk6Ot5B3Ia8xm42g+jQecXtgL7M35KJVmS8Y5mIP/yETRyGJpKKEVmWkTQUQcHOfKL083D6SqgZIViOuQ8EQHRxzmJkgGHcfYLBeK7Nadc1kaqAd+3wzLATBryaIgBBAwSQdB04t89/1O/w1cDnyilFU='
const Question_URL = 'https://inspct.career.go.kr/openapi/test/questions?apikey=8f65744f11f9b7e8fc2b7c28617e9d09&q=6'
const Result_URL = 'https://inspct.career.go.kr/openapi/test/report?apikey=8f65744f11f9b7e8fc2b7c28617e9d09&qestnrSeq=6'
const fs = require('fs');
const path = require('path');
const HTTPS = require('https');
const domain = "www.skdhkfkdy.tk"
const sslport = 23023;
const bodyParser = require('body-parser');
var app = express();
app.use(bodyParser.json());

app.post('/hook', function (req, res) {

    var eventObj = req.body.events[0];
    var source = eventObj.source;
    var message = eventObj.message;
    var contents;
    // request log
    console.log('======================', new Date() ,'======================');
    console.log('[request]', req.body);
    console.log('[request source] ', eventObj.source);
    console.log('[request message]', eventObj.message);

    test_load(eventObj.replyToken);
  
    res.sendStatus(200);
});
function reply_loaded(replyToken,question,answer){
    request.post({
        url: TARGET_URL,
        headers: {
            'Authorization': `Bearer ${TOKEN}`
        },
        json: {
            "replyToken":replyToken,
            "messages":[
                {
                    "type":"text",
                    "text":question
                },{
                    "type":"text",
                    "text":answer
                }]
            }
        },(error, response, body) => {
            console.log(body)
    });
}
function test_load(replyToken){
    var contents;
    var question;
    var answer;
    request.get({
        url:Question_URL
    },function(err,res,body){
        contents = JSON.parse(body);
        for(var i=0;i<28;i++){
            console.log("=====================================");
            question = contents["RESULT"][i]["question"];
            answer = contents["RESULT"][i]["answer01"]+"/"+contents["RESULT"][i]["answer02"];
            reply_loaded(replyToken,question,answer);
            console.log("replyed");
            console.log("=====================================");
        }
    });
}

// function test(replyToken, answersheet){

// }

// function trans(replyToken, message) {

//     request.post(
//         {
//             url: Question_URL,
//             headers: {
//                 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8',
//                 'X-Naver-Client-Id': `${PAPAGO_ID}`,
//                 'X-Naver-Client-Secret': `${PAPAGO_SECRET}`
//             },
//             body: 'source=ko&target=en&text=' + message,
//             json:true
//         },(error, response, body) => {
//             if(!error && response.statusCode == 200) {
//                 console.log(body.message);
//                 var transMessage = body.message.result.translatedText;
//                 request.post(
//                     {
//                         url: TARGET_URL,
//                         headers: {
//                             'Authorization': `Bearer ${TOKEN}`
//                         },
//                         json: {
//                             "replyToken":replyToken,
//                             "messages":[
//                                 {
//                                     "type":"text",
//                                     "text":transMessage
//                                 }
//                             ]
//                         }
//                     },(error, response, body) => {
//                         console.log(body)
//                     }
//                 );
//             }
//         }
//     )
// }

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);
  }