AWS - EC2, EBS, ELB, SSM, VPC & VPN Enum
Last updated
Last updated
Apprenez et pratiquez le hacking AWS :HackTricks Training AWS Red Team Expert (ARTE) Apprenez et pratiquez le hacking GCP : HackTricks Training GCP Red Team Expert (GRTE)
Apprenez ce qu'est un VPC et ses composants dans :
AWS - VPC & Networking Basic InformationAmazon EC2 est utilisé pour initier des serveurs virtuels. Il permet la configuration de la sécurité et du réseautage ainsi que la gestion du stockage. La flexibilité d'Amazon EC2 est évidente dans sa capacité à faire évoluer les ressources à la hausse et à la baisse, s'adaptant efficacement aux variations des besoins ou aux pics de popularité. Cette fonctionnalité réduit la nécessité de prévisions de trafic précises.
Choses intéressantes à énumérer dans EC2 :
Machines Virtuelles
Clés SSH
Données Utilisateur
EC2/AMIs/Snapshots existants
Réseautage
Réseaux
Sous-réseaux
IPs Publiques
Ports ouverts
Connexions intégrées avec d'autres réseaux en dehors d'AWS
Utiliser des rôles pour accorder des permissions aux applications qui s'exécutent sur des instances EC2 nécessite un peu de configuration supplémentaire. Une application s'exécutant sur une instance EC2 est abstraite d'AWS par le système d'exploitation virtualisé. En raison de cette séparation supplémentaire, vous devez effectuer une étape supplémentaire pour attribuer un rôle AWS et ses permissions associées à une instance EC2 et les rendre disponibles pour ses applications.
Cette étape supplémentaire est la création d'un profil d'instance attaché à l'instance. Le profil d'instance contient le rôle et peut fournir les identifiants temporaires du rôle à une application qui s'exécute sur l'instance. Ces identifiants temporaires peuvent ensuite être utilisés dans les appels API de l'application pour accéder aux ressources et limiter l'accès uniquement à celles que le rôle spécifie. Notez que seul un rôle peut être attribué à une instance EC2 à la fois, et toutes les applications sur l'instance partagent le même rôle et les mêmes permissions.
Les métadonnées EC2 d'AWS sont des informations sur une instance Amazon Elastic Compute Cloud (EC2) qui sont disponibles pour l'instance à l'exécution. Ces métadonnées sont utilisées pour fournir des informations sur l'instance, telles que son ID d'instance, la zone de disponibilité dans laquelle elle s'exécute, le rôle IAM associé à l'instance et le nom d'hôte de l'instance.
Dans la page suivante, vous pouvez vérifier comment abuser des permissions EC2 pour élever les privilèges :
AWS - EC2 PrivescLes snapshots Amazon EBS (Elastic Block Store) sont essentiellement des sauvegardes statiques des volumes EBS AWS. En d'autres termes, ce sont des copies des disques attachés à une instance EC2 à un moment donné. Les snapshots EBS peuvent être copiés entre régions et comptes, ou même téléchargés et exécutés localement.
Les snapshots peuvent contenir des informations sensibles telles que du code source ou des clés API, donc, si vous en avez l'occasion, il est recommandé de les vérifier.
Une AMI est utilisée pour lancer une instance EC2, tandis qu'un Snapshot EC2 est utilisé pour sauvegarder et récupérer des données stockées sur un volume EBS. Bien qu'un Snapshot EC2 puisse être utilisé pour créer une nouvelle AMI, ce n'est pas la même chose qu'une AMI, et cela n'inclut pas d'informations sur le système d'exploitation, le serveur d'application ou d'autres logiciels nécessaires pour exécuter une application.
Dans la page suivante, vous pouvez vérifier comment abuser des permissions EBS pour élever les privilèges :
AWS - EBS PrivescAmazon Simple Systems Manager (SSM) permet de gérer à distance des flottilles d'instances EC2 pour faciliter leur administration. Chacune de ces instances doit exécuter le service SSM Agent car c'est ce service qui recevra les actions et les exécutera via l'API AWS.
Le SSM Agent permet à Systems Manager de mettre à jour, gérer et configurer ces ressources. L'agent traite les demandes du service Systems Manager dans le Cloud AWS, puis les exécute comme spécifié dans la demande.
Le SSM Agent est préinstallé dans certaines AMIs ou vous devez les installer manuellement sur les instances. De plus, le rôle IAM utilisé à l'intérieur de l'instance doit avoir la politique AmazonEC2RoleforSSM attachée pour pouvoir communiquer.
Vous pouvez vérifier dans une instance EC2 si Systems Manager fonctionne simplement en exécutant :
Dans la page suivante, vous pouvez vérifier comment abuser des permissions SSM pour escalader les privilèges :
AWS - SSM PrivescElastic Load Balancing (ELB) est un service de répartition de charge pour les déploiements Amazon Web Services (AWS). ELB distribue automatiquement le trafic d'application entrant et ajuste les ressources pour répondre aux demandes de trafic.
AWS Nitro est une suite de technologies innovantes qui forme la plateforme sous-jacente pour les instances AWS EC2. Introduit par Amazon pour améliorer la sécurité, la performance et la fiabilité, Nitro tire parti de composants matériels personnalisés et d'un hyperviseur léger. Il abstrait une grande partie de la fonctionnalité de virtualisation traditionnelle vers du matériel et des logiciels dédiés, minimisant la surface d'attaque et améliorant l'efficacité des ressources. En déchargeant les fonctions de virtualisation, Nitro permet aux instances EC2 de fournir une performance proche du bare-metal, ce qui est particulièrement bénéfique pour les applications gourmandes en ressources. De plus, la puce de sécurité Nitro garantit spécifiquement la sécurité du matériel et du firmware, renforçant ainsi son architecture robuste.
Obtenez plus d'informations et comment l'énumérer à partir de :
AWS - Nitro EnumUn VPN permet de connecter votre réseau sur site (site-à-site VPN) ou les ordinateurs portables des travailleurs (Client VPN) avec un AWS VPC afin que les services puissent être accessibles sans avoir besoin de les exposer à Internet.
Passerelle Client :
Une Passerelle Client est une ressource que vous créez dans AWS pour représenter votre côté d'une connexion VPN.
C'est essentiellement un dispositif physique ou une application logicielle de votre côté de la connexion VPN Site-à-Site.
Vous fournissez des informations de routage et l'adresse IP publique de votre dispositif réseau (comme un routeur ou un pare-feu) à AWS pour créer une Passerelle Client.
Elle sert de point de référence pour établir la connexion VPN et n'entraîne pas de frais supplémentaires.
Passerelle Privée Virtuelle :
Une Passerelle Privée Virtuelle (VPG) est le concentrateur VPN du côté Amazon de la connexion VPN Site-à-Site.
Elle est attachée à votre VPC et sert de cible pour votre connexion VPN.
VPG est le point de terminaison du côté AWS pour la connexion VPN.
Elle gère la communication sécurisée entre votre VPC et votre réseau sur site.
Connexion VPN Site-à-Site :
Une connexion VPN Site-à-Site connecte votre réseau sur site à un VPC via un tunnel VPN IPsec sécurisé.
Ce type de connexion nécessite une Passerelle Client et une Passerelle Privée Virtuelle.
Il est utilisé pour une communication sécurisée, stable et cohérente entre votre centre de données ou réseau et votre environnement AWS.
Typiquement utilisé pour des connexions régulières et à long terme, et est facturé en fonction de la quantité de données transférées via la connexion.
Point de terminaison Client VPN :
Un point de terminaison Client VPN est une ressource que vous créez dans AWS pour activer et gérer les sessions VPN client.
Il est utilisé pour permettre à des dispositifs individuels (comme des ordinateurs portables, des smartphones, etc.) de se connecter en toute sécurité aux ressources AWS ou à votre réseau sur site.
Il diffère du VPN Site-à-Site en ce qu'il est conçu pour des clients individuels plutôt que de connecter des réseaux entiers.
Avec le Client VPN, chaque dispositif client utilise un logiciel client VPN pour établir une connexion sécurisée.
Vous pouvez trouver plus d'informations sur les avantages et les composants des VPN AWS ici.
Identifiants Temporaires Locaux
Lorsque le client VPN AWS est utilisé pour se connecter à un VPN, l'utilisateur se connecte généralement à AWS pour accéder au VPN. Ensuite, certains identifiants AWS sont créés et stockés localement pour établir la connexion VPN. Ces identifiants sont stockés dans $HOME/.config/AWSVPNClient/TemporaryCredentials/<region>/temporary-credentials.txt
et contiennent une AccessKey, une SecretKey et un Token.
Les identifiants appartiennent à l'utilisateur arn:aws:sts::<acc-id>:assumed-role/aws-vpn-client-metrics-analytics-access-role/CognitoIdentityCredentials
(TODO : rechercher plus sur les permissions de ces identifiants).
Fichiers de configuration opvn
Si une connexion VPN a été établie, vous devriez rechercher des fichiers de configuration .opvn
dans le système. De plus, un endroit où vous pourriez trouver les configurations est dans $HOME/.config/AWSVPNClient/OpenVpnConfigs
Apprenez et pratiquez le Hacking AWS :HackTricks Training AWS Red Team Expert (ARTE) Apprenez et pratiquez le Hacking GCP : HackTricks Training GCP Red Team Expert (GRTE)