Ubuntu

Debug functions

Showing 1 changed file with 127 additions and 128 deletions
......@@ -15,30 +15,30 @@ var cron = require('node-cron');
var stock_code = "005930"
app.use(bodyParser.json());
let stockList = [];
fs.readFile('./stock_names.txt', 'utf8', (err,data) => { // 파일 import하고 stockList로 저장
if (err){
console.error(err)
return
}
var tempstockList = data.toString().split("\n"); // ex) stockList = [[012312 ~~],[123012 ~~],[192312 ~~],[192310 ~~],[...]]
// console.log("tempStockList:", tempstockList);
for (let i=0; i<tempstockList.length; i++){
stockList[i] = (tempstockList[i].split("\t")); // ex) stockList = [[012312,~~],[1230012,~~],[1923,~~],[192310,~~],[...]]
}
// console.log(111)
// console.log(stockList.length)
// for (i in stockList) {
// console.log(stockList[i]);
// }
})
app.post('/hook', function (req, res) {
var eventObj = req.body.events[0];
var source = eventObj.source;
var message = eventObj.message;
let stockList = [];
//import './stock_names.txt';
fs.readFile('./stock_names.txt', 'utf8', (err,data) => { // 파일 import하고 stockList로 저장
if (err){
console.error(err)
return
}
var tempstockList = data.toString().split("\n"); // ex) stockList = [[012312 ~~],[123012 ~~],[192312 ~~],[192310 ~~],[...]]
for (i in tempstockList){
var stockList = tempstockList[i].toString().split(" "); // ex) stockList = [[012312,~~],[1230012,~~],[1923,~~],[192310,~~],[...]]
}
// for (i in stockList) {
// console.log(stockList[i]);
// }
})
// request log
console.log('======================', new Date() ,'======================');
console.log('[request]', req.body);
......@@ -46,62 +46,22 @@ app.post('/hook', function (req, res) {
console.log('[request message]', eventObj.message);
var s_code = get_stock_code(stockList,stock_code,eventObj.replyToken,eventObj.message.text);
//var wanted_price = get_wanted_price(eventObj.replyToken,eventObj.message.text);
cron.schedule('*/5 * * * *', () => {
compare(s_code, wanted_price);
console.log('It works')
});
// if (eventObj.message.text == "영어"){
// lan = "en"
// }
// else if (eventObj.message.text == "일본어"){
// lan = "ja"
// }
// else if (eventObj.message.text == "프랑스어"){
// lan = "fr"
// }
// else{
// trans(eventObj.replyToken, eventObj.message.text);
// }
// request.post(
// {
// url: TARGET_URL,
// headers: {
// 'Authorization': `Bearer ${TOKEN}`
// },
// json: {
// "replyToken":eventObj.replyToken,
// "messages":[
// {
// "type":"text",
// "text":"Hello, user"
// },
// {
// "type":"text",
// "text":"May I help you?"
// }
// ]
// }
// },(error, response, body) => {
// console.log(body)
// });
// var wanted_price = get_wanted_price(eventObj.replyToken,eventObj.message.text);
//console.log("s_code:", s_code)
if (s_code != -1){
cron.schedule('*/2 * * * *', () => {
compare(s_code[0], s_code[1],eventObj.replyToken);
});
// compare(s_code[0], s_code[1],eventObj.replyToken);
}
res.sendStatus(200);
});
function get_stock_code(stockList,stock_code,replyToken,message){
var temp = message.toString().split(" ");
var wanted_stock_name = temp[0];
var wanted_stock_price = temp[1];
if (wanted_stock_price < 0){
if (temp.length != 2){
request.post(
{
url: TARGET_URL,
......@@ -113,23 +73,59 @@ function get_stock_code(stockList,stock_code,replyToken,message){
"messages":[
{
"type":"text",
"text":"Price must be positive number"
"text":"Please type in like the following form"
},
{
"type":"text",
"text":"(기업명) (가격)"
}
]
}
},(error, response, body) => {
console.log(body)
});
return -1;
}
else{
//console.log(temp)
var wanted_stock_name = temp[0];
var wanted_stock_price = temp[1];
var is_in_list = false;
console.log("stockList:",stockList.length);
if (wanted_stock_price < 0){ // 원하는 가격 입력받음 (0 이상만)
request.post(
{
url: TARGET_URL,
headers: {
'Authorization': `Bearer ${TOKEN}`
},
json: {
"replyToken":replyToken,
"messages":[
{
"type":"text",
"text":"Price must be positive number"
},
]
}
},(error, response, body) => {
console.log(body)
});
return -1;
}
for (let i = 0; i<stockList.length; i++) {
if (wanted_stock_name == stockList[i][1]){ // 입력한거 나오면 코드로 바꿔줌
stock_code = stockList[i][0]
return stock_code
for (let i = 0; i<stockList.length; i++) {
if (wanted_stock_name == stockList[i][1]){ // 입력한거 나오면 코드로 바꿔줌
// console.log(123)
stock_code = stockList[i][0]
is_in_list = true
return [stock_code, wanted_stock_price]
}
}
else{ // stockList에 없으면 없다고 보냄
if (is_in_list == false) { // stockList에 없으면 없다고 보냄
request.post(
{
url: TARGET_URL,
......@@ -148,66 +144,69 @@ function get_stock_code(stockList,stock_code,replyToken,message){
},(error, response, body) => {
console.log(body)
});
}
return -1;
}
}
}
// function get_wanted_price(replyToken,message){ // 원하는 가격 입력받음 (0 이상만)
// if (message < 0){
// request.post(
// {
// url: TARGET_URL,
// headers: {
// 'Authorization': `Bearer ${TOKEN}`
// },
// json: {
// "replyToken":eventObj.replyToken,
// "messages":[
// {
// "type":"text",
// "text":"Price must be positive number"
// },
// ]
// }
// },(error, response, body) => {
// console.log(body)
// });
// }
// }
function compare(s_code, wanted_price){
const temp = axios.get(`https://finance.naver.com/item/main.nhn?code=${s_code}%22`).then(
function compare(s_code, wanted_price,replyToken){
const temp = axios.get(`https://finance.naver.com/item/main.nhn?code=${s_code}`).then(
res => {
let urList = [];
// console.log(res.data)
const $ = cheerio.load(res.data)
const $bodyList = $("dl.blind").children("dd").text();
const result = $bodyList.slice(73, 80) // 실시간으로 변하는 주식 가격 scrape
console.log(result)
let $bodyList = $("dl.blind").text();
$bodyList = $bodyList.split('\n')[5];
$bodyList = $bodyList.slice(14, $bodyList.length);
$bodyList = $bodyList.split(' ')[0];
// console.log($bodyList)
let result = $bodyList // 실시간으로 변하는 주식 가격 scrape
result = result.replace(',', '')
console.log("current price:",parseInt(result))
if (parseInt(result) >= wanted_price){
request.post(
{
url: TARGET_URL,
headers: {
'Authorization': `Bearer ${TOKEN}`
},
json: {
"replyToken":replyToken,
"messages":[
{
"type":"text",
"text":"Reached wanted price!"
},
]
}
},(error, response, body) => {
console.log(body)
});
}
}
)
if (int(result) <= wanted_price){
request.post(
{
url: TARGET_URL,
headers: {
'Authorization': `Bearer ${TOKEN}`
},
json: {
"replyToken":replyToken,
"messages":[
{
"type":"text",
"text":"Reached wanted price!"
},
]
}
},(error, response, body) => {
console.log(body)
});
}
// if (parseInt(result) <= wanted_price){
// request.post(
// {
// url: TARGET_URL,
// headers: {
// 'Authorization': `Bearer ${TOKEN}`
// },
// json: {
// "replyToken":replyToken,
// "messages":[
// {
// "type":"text",
// "text":"Reached wanted price!"
// },
// ]
// }
// },(error, response, body) => {
// console.log(body)
// });
// }
......