CloudFront не извлекает данные из пользовательского источника для корневого URL с помощью Lambda @ Edge - PullRequest
2 голосов
/ 07 мая 2019

У меня есть функция Lambda @ Edge, которая решает, какой источник использовать в запросе источника, в зависимости от значения заголовка.

Это не работает для корневого URL (mysite.com), но работает для подчиненных (mysite.com/sth/abc).Я ищу помощь, пытаясь выяснить, почему он не работает для корневого URL.

Это выглядит так:

exports.handler = (event, context, callback) => {
  const request = event.Records[0].cf.request;
  const isBot = headers['formaviva-agent'] && headers['formaviva-agent'][0].value === 'bot';

  console.log("request before" + JSON.stringify(request));
  console.log("isBot:" + isBot);

  const shouldPrerender = isBot;

  if (shouldPrerender) {
    request.origin = {
        custom: {
            domainName: 'fast.formaviva.com',
            port: 80,
            protocol: 'http',
            path: '',
            sslProtocols: ['TLSv1', 'TLSv1.1'],
            readTimeout: 5,
            keepaliveTimeout: 5,
            customHeaders: {}
        }
    };

    request.headers['host'] = [{ key: 'host', value: 'fast.formaviva.com'}];
    console.log("request after" + JSON.stringify(request));
  }

  callback(null, request);
};

По умолчанию используется статический хостинг страниц S3.formaviva-agent устанавливается в лямбда-функции Viewer Request, которая проверяет, принадлежит ли User-Agent боту.

Formaviva-agent занесен в белый список.

Судя по журналам, все идет хорошо, бот распознается, а источник меняется на пользовательский:

2019-05-07T09:56:45.627Z    3a2831f4-2a6b-46ea-8850-d89651a9b19e    request after
{
"clientIp": "92.37.21.9",
"headers": {
    "if-modified-since": [
        {
            "key": "If-Modified-Since",
            "value": "Mon, 06 May 2019 10:50:39 GMT"
        }
    ],
    "if-none-match": [
        {
            "key": "If-None-Match",
            "value": "W/\"41cc-16a8cc45892\""
        }
    ],
    "user-agent": [
        {
            "key": "User-Agent",
            "value": "Amazon CloudFront"
        }
    ],
    "via": [
        {
            "key": "Via",
            "value": "1.1 b38e161751a953866db739b688c09996.cloudfront.net (CloudFront)"
        }
    ],
    "formaviva-agent": [
        {
            "key": "formaviva-agent",
            "value": "bot"
        }
    ],
    "x-forwarded-for": [
        {
            "key": "X-Forwarded-For",
            "value": "92.37.21.9"
        }
    ],
    "host": [
        {
            "key": "host",
            "value": "fast.formaviva.com"
        }
    ]
},
"method": "GET",
"origin": {
    "custom": {
        "domainName": "fast.formaviva.com",
        "port": 80,
        "protocol": "http",
        "path": "",
        "sslProtocols": [
            "TLSv1",
            "TLSv1.1"
        ],
        "readTimeout": 5,
        "keepaliveTimeout": 5,
        "customHeaders": {}
    }
},
"querystring": "",
"uri": "/index.html"
}

В этом случае Cloudfront по-прежнему обслуживает контент из источника S3.Пользовательский сервер происхождения не получает (подтверждено).Даже если указано пользовательское происхождение.Почему?

...