index.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. // Smiiirl Compteur - Entreprise Spirit SA
  2. // https://git.heroku.com/smiiile-spirit.git
  3. // https://smiiile-spirit.herokuapp.com
  4. const path = require('path');
  5. const express = require('express');
  6. const app = express();
  7. const port = process.env.PORT || 3000;
  8. const bodyParser = require('body-parser');
  9. const validator = require('validator');
  10. const API = require('./lib/API');
  11. const mail = require('./notification.js')
  12. let info = {
  13. followers: 99999,
  14. companyID: 991997, // spirit_3 company page
  15. orgaName: "spirit_3",
  16. tokens: null,
  17. expire: 0,
  18. active: true,
  19. updateTime: 4000, // 25000 Api call / 24H,
  20. error: 0
  21. }
  22. if (process.env.access_token) {
  23. info.tokens = process.env.access_token
  24. info.active = true
  25. }
  26. if (process.env.expire) info.expire = process.env.expire
  27. async function watchLinkedin(){
  28. if (info.active){
  29. const getFollowers = API.getCompanyFollowers(info)
  30. getFollowers.then( (followersNb) => {
  31. if (followersNb.firstDegreeSize) {
  32. info.followers = followersNb.firstDegreeSize
  33. process.env.lastFollowers = info.followers
  34. // cleanUp error
  35. info.error = 0
  36. }
  37. }).catch( (err) => {
  38. console.log("[DEBUG-LOG][watchLinkedin ERROR]", info.error, err);
  39. info.error++
  40. if (info.error > 50) {
  41. info.active = false
  42. mail.notif(process.env.usermail, process.env.pswd, process.env.contact);
  43. }
  44. });
  45. }
  46. }
  47. setInterval(watchLinkedin, info.updateTime)
  48. // --- --- --- --- --- --- EXPRESS SERVER
  49. app.disable('x-powered-by');
  50. app.use(bodyParser.urlencoded({ extended: true}));
  51. app.get('/', (req, res) => {
  52. res.json({number: info.followers})
  53. });
  54. app.get('/auth', (req, res) => {
  55. res.redirect(API.getAuthorizationUrl());
  56. });
  57. app.get('/callback', async (req, res) => {
  58. if(!req.query.code) {
  59. res.redirect('/');
  60. return;
  61. }
  62. try {
  63. const data = await API.getAccessToken(req);
  64. if(data.access_token) {
  65. info.token = data.access_token;
  66. info.authorized = true;
  67. info.active = true
  68. process.env.access_token = info.token
  69. process.env.expire = data.expire ? data.expire : 0
  70. }
  71. res.redirect('/');
  72. } catch(err) {
  73. res.json(err);
  74. }
  75. });
  76. app.get('/test', async (req, res) => {
  77. try {
  78. const id = await API.getLinkedinId(info);
  79. console.log("[getLinkedinId]", id)
  80. res.json(id)
  81. } catch(err) {
  82. res.send(err);
  83. }
  84. });
  85. app.get('/company', async (req, res) => {
  86. try {
  87. await API.getCompanyFollowers(info)
  88. .then( (followersNb) => {
  89. if (followersNb.firstDegreeSize) {
  90. info.followers = followersNb.firstDegreeSize
  91. process.env.lastFollowers = info.followers
  92. res.json(info.followers)
  93. } else res.json({"error": "firstDegreeSize not available"})
  94. }).catch( (err) => {
  95. info.error++
  96. if (info.error > 50) mail.notif(process.env.usermail, process.env.pswd, process.env.contact);
  97. })
  98. } catch(err) {
  99. res.send(err);
  100. }
  101. });
  102. app.listen(process.env.PORT);