Не можете понять, почему мой app.get запускается дважды? - PullRequest
0 голосов
/ 13 сентября 2018

У меня есть app.get, что внутри довольно логично. Который все прекрасно работает, если не считать логики, вызываемой дважды по какой-то причине. Когда я что-то сохранял в db, я заметил, что это сохранит две строки.

Таким образом, я поместил console.log в эту область и достаточно уверенно, что он регистрировал его дважды.

Есть причина, почему это происходит?

app.get('/shopify/callback', (req, res) => {

  const { shop, hmac, code, state } = req.query;
  const stateCookie = cookie.parse(req.headers.cookie).state;

  if (state !== stateCookie) {
    return res.status(403).send('Request origin cannot be verified');
  }

  if (shop && hmac && code) {

    // DONE: Validate request is from Shopify
    const map = Object.assign({}, req.query);
    delete map['signature'];
    delete map['hmac'];
    const message = querystring.stringify(map);
    const providedHmac = Buffer.from(hmac, 'utf-8');
    const generatedHash = Buffer.from(
      crypto
        .createHmac('sha256', config.oauth.client_secret)
        .update(message)
        .digest('hex'),
        'utf-8'
      );
    let hashEquals = false;

    try {
      hashEquals = crypto.timingSafeEqual(generatedHash, providedHmac)
    } catch (e) {
      hashEquals = false;
    };

    if (!hashEquals) {
      return res.status(400).send('HMAC validation failed');
    }

    // DONE: Exchange temporary code for a permanent access token
    const accessTokenRequestUrl = 'https://' + shop + '/admin/oauth/access_token';
    const accessTokenPayload = {
      client_id: config.oauth.api_key,
      client_secret: config.oauth.client_secret,
      code,
    };

    request.post(accessTokenRequestUrl, { json: accessTokenPayload })
    .then((accessTokenResponse) => {

      const accessToken = accessTokenResponse.access_token;
      // DONE: Use access token to make API call to 'shop' endpoint
      const shopRequestUrl = 'https://' + shop + '/admin/shop.json';
      const shopRequestHeaders = {
        'X-Shopify-Access-Token': accessToken,
      }

     request.get(shopRequestUrl, { headers: shopRequestHeaders })
      .then((shopResponse) => {

        const response = JSON.parse(shopResponse);
        const shopData = response.shop;

        console.log('BEING CALLED TWICE...')

        res.render('pages/brand_signup',{
          shop: shopData.name
        })

      })
      .catch((error) => {
        res.status(error.statusCode).send(error.error.error_description);
      });


    })
    .catch((error) => {
      res.status(error.statusCode).send(error.error.error_description);
    }); 


  } else {
    res.status(400).send('Required parameters missing');
  }

});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...