Skip to content

Instantly share code, notes, and snippets.

...
if(event.message.text === 'register') {
let access_token = await issue_access_token();
access_token = JSON.parse(access_token);
// 7. Initialize LINE Header
// 8. Store Access Token to Real Time Database
// 9. Reply result to User Chat Room
}
const initialLINE = async(token_type, token) => {
LINE_HEADER = {
"Content-Type": "application/json",
"Authorization": `${token_type} ${token}`
};
}
...
if(event.message.text === 'register') {
let access_token = await issue_access_token();
access_token = JSON.parse(access_token);
await initialLINE(access_token['token_type'], access_token['access_token']);
// 8. Store Access Token to Real Time Database
// 9. Reply result to User Chat Room
}
...
if(event.message.text === 'register') {
let access_token = await issue_access_token();
access_token = JSON.parse(access_token);
await initialLINE(access_token['token_type'], access_token['access_token']);
await admin.database().ref('token').child(event.source.userId).set(access_token);
// 9. Reply result to User Chat Room
}
const reply = (token, payload) => {
return request.post({
uri: `${LINE_MESSAGING_API}/reply`,
headers: LINE_HEADER,
body: JSON.stringify({
replyToken: token,
messages: [payload]
})
})
}
...
if(event.message.text === 'register') {
let access_token = await issue_access_token();
access_token = JSON.parse(access_token);
await initialLINE(access_token['token_type'], access_token['access_token']);
await admin.database().ref('token').child(event.source.userId).set(access_token);
reply(event.replyToken, {
type: 'text',
text: '\uDBC0\uDC7F ลงทะเบียน token เรียบร้อยแล้ว เอาไปใช้ได้เลย\n\n' + JSON.stringify(access_token)
...
} else if(event.message.text === 'revoke') {
let token = await admin.database().ref('token').child(event.source.userId).once('value');
// 11. Initialize LINE Header
// 12. Remove Access Token from RTDB
// 13. Reply result to User Chat Room
// 14. Revoke Access Token
}
...
...
} else if(event.message.text === 'revoke') {
let token = await admin.database().ref('token').child(event.source.userId).once('value');
await initialLINE(token.val().token_type, token.val().access_token );
// 12. Remove Access Token from RTDB
// 13. Reply result to User Chat Room
// 14. Revoke Access Token
}
...
exports.AccessTokenBot = functions.region(region).runWith(runtimeOpts).https.onRequest(async (req, res) => {
let event = req.body.events[0]
switch (event.type) {
case 'message':
if (event.message.type === 'text') {
if(event.message.text === 'register') {
// 6. Call API for Create Access Token
// 7. Initialize LINE Header
// 8. Store Access Token to Real Time Database
// 9. Reply result to User Chat Room
...
} else if(event.message.text === 'revoke') {
let token = await admin.database().ref('token').child(event.source.userId).once('value');
await initialLINE(token.val().token_type, token.val().access_token );
await admin.database().ref('token').child(event.source.userId).remove();
// 13. Reply result to User Chat Room
// 14. Revoke Access Token
}
...