Невозможно отучить людей изучать самые ненужные предметы.
Введение в CSS
Преимущества стилей
Добавления стилей
Типы носителей
Базовый синтаксис
Значения стилевых свойств
Селекторы тегов
Классы
CSS3
Надо знать обо всем понемножку, но все о немногом.
Идентификаторы
Контекстные селекторы
Соседние селекторы
Дочерние селекторы
Селекторы атрибутов
Универсальный селектор
Псевдоклассы
Псевдоэлементы
Кто умеет, тот делает. Кто не умеет, тот учит. Кто не умеет учить - становится деканом. (Т. Мартин)
Группирование
Наследование
Каскадирование
Валидация
Идентификаторы и классы
Написание эффективного кода
Вёрстка
Изображения
Текст
Цвет
Линии и рамки
Углы
Списки
Ссылки
Дизайны сайтов
Формы
Таблицы
CSS3
HTML5
Блог для вебмастеров
Новости мира Интернет
Сайтостроение
Ремонт и советы
Все новости
Справочник от А до Я
HTML, CSS, JavaScript
Афоризмы о учёбе
Статьи об афоризмах
Все Афоризмы
Помогли мы вам |
Как работает AWS Lambda? Если простыми словами: ты добавляешь свой скрипт и задаешь триггер или событие, при наступлении которого будет запускаться этот код. Больше делать ничего не нужно, потому что обо всем другом — администрировании, мониторинге работы, безопасности, журналах, логах — позаботится сервис AWS Lambda. Когда событий нет, лямбда не выполняется, соответственно, ресурсы не потребляются.
Лямбда‑функция — это часть кода, которая выполняется каждый раз, когда срабатывает триггер.
Существует три типа триггеров, отличаются они способом вызова:
При этом вызов возможно выполнить и с помощью API Gateway.
Служба API Gateway упрощает разработчикам работу с API. Поддерживается REST, HTTP и WebSocket API.
Мы можем привязать API Gateway к какому‑то сервису, мобильному приложению, даже к IOT, — главное, чтобы у них был доступ в интернет. После этого оно будет стучать на API-шлюз, с которого и станут вызываться требуемые действия.
Чаще всего через лямбду в облако не попадают. Но в случае обнаружения функции, гейтвея, создания полной ссылки и требуемого набора параметров можно все‑таки попробовать. Например, если лямбда‑функция принимает какую‑либо команду для запуска в cmd:
https://i8jee1mn2f.execute-api.us-east-2.amazonaws.com/prod/system?cmd=env
На первом этапе нужно хорошенько разведать обстановку и поискать уязвимые места. На помощь нам придет AWS CLI. Чтобы увидеть все лямбда‑функции, воспользуемся следующей командой:
awslambdalist-functions
Получить лямбда‑функции в отдельном регионе:
aws lambda list-functions --regionus-east-1
FunctionArn
— уникальный идентификатор функции;Runtime
— язык, на котором написана функция;Role
— роль, которую имеет лямбда‑функция. Возможно, определенная лямбда‑функция имеет доступ к другим службам. Соответственно, мы также можем определить политики, привязанные к лямбда‑функции;Layers
— зависимости лямбда‑функции.Получить информацию о конкретной лямбда‑функции (в том числе исходный код) можно следующим образом:
awslambdaget-function--function-name<function-name>[--regioneu-west-1--profiledemo]
Пример:
awslambdaget-function--function-namePentestingForFun
В приведенном выше примере мы видим раздел Code
, а в нем — Location
. То есть код извлекается по этому пути, в данном случае это S3-бакет awslambda-us-west2-tasks
. Перейдя по указанной ссылке (либо порывшись в указанном бакете), мы сможем скачать код лямбда‑функции.
При этом в выводе данной команды есть огромная структура Configuration
, которую тоже стоит обязательно посмотреть. Во время пентестов мы часто обнаруживали здесь учетные данные.
Исходный код зависимости можно получить вот так:
awslambdaget-layer-version--layer-name<LayerName>--version-number<VersionNumber>
Пример:
awslambdaget-layer-version--layer-namerequest-library--version-number1
Теперь обрати внимание на способы вызова функции.
awslambdaget-policy--function-name<function-name>
Пример:
awslambdaget-policy--function-namePentestingForFun
Service
— то, кому разрешено дергать функцию;Action
— что может сделать Service
;Resource
— какие объекты могут быть вызваны.В лямбда‑функциях иногда встречается раздел Condition
. Он отвечает за «фильтрацию» — каким методом и каким образом вызывается лямбда. Именно в нем всегда будет прятаться айдишник, по которому ты сможешь определить, к какому гейтвею привязана лямбда‑функция.
В данном случае uj3lq1cu8e
— REST API ID. При этом триггер может сработать и от изменений в чем‑либо. Для получения информации о подобных событиях существует вот такой командлет:
awslambdalist-event-source-mappings--function-name<function-name>
Пример:
awslambdalist-event-source-mappings--function-namePentestingForFun
В этом случае используется Amazon Simple Queue Service (SQS) — служба очереди сообщений.
После изучения доступных лямбда‑функций пора восстанавливать URL, который приведет к ее вызову. Чтобы увидеть все REST APIs (получить айдишник, так как Region зачастую схож с большинством регионов, в котором стоят ЕС2-инстансы), воспользуемся следующей командой:
awsapigatewayget-rest-apis
|
|