GCP - Cloud SQL Post Exploitation
Cloud SQL
Aby uzyskać więcej informacji na temat Cloud SQL, sprawdź:
pageGCP - Cloud SQL Enumcloudsql.instances.update
, (cloudsql.instances.get
)
cloudsql.instances.update
, (cloudsql.instances.get
)Aby połączyć się z bazami danych, potrzebujesz tylko dostępu do portu bazy danych i znać nazwę użytkownika i hasło, nie ma żadnych wymagań IAM. Więc łatwym sposobem uzyskania dostępu, zakładając, że baza danych ma publiczny adres IP, jest zaktualizowanie dozwolonych sieci i umożliwienie dostępu z własnego adresu IP.
Można również użyć --no-backup
aby zakłócić tworzenie kopii zapasowych bazy danych.
Ponieważ nie jestem całkowicie pewien, jakie są uprawnienia cloudsql.instances.connect
i cloudsql.instances.login
, jeśli wiesz, wyślij PR!
cloudsql.users.list
cloudsql.users.list
Pobierz listę wszystkich użytkowników bazy danych:
cloudsql.users.create
cloudsql.users.create
Ta uprawnienie umożliwia utworzenie nowego użytkownika wewnątrz bazy danych:
cloudsql.users.update
cloudsql.users.update
Ta uprawnienie umożliwia aktualizację użytkownika wewnątrz bazy danych. Na przykład, możesz zmienić jego hasło:
cloudsql.instances.restoreBackup
, cloudsql.backupRuns.get
cloudsql.instances.restoreBackup
, cloudsql.backupRuns.get
Kopie zapasowe mogą zawierać stare wrażliwe informacje, więc warto je sprawdzić. Przywróć kopię zapasową wewnątrz bazy danych:
Aby to zrobić w bardziej dyskretny sposób, zaleca się utworzenie nowej instancji SQL i odzyskanie danych tam, zamiast w obecnie działających bazach danych.
cloudsql.backupRuns.delete
cloudsql.backupRuns.delete
To uprawnienie umożliwia usuwanie kopii zapasowych:
cloudsql.instances.export
, storage.objects.create
cloudsql.instances.export
, storage.objects.create
Eksportuj bazę danych do Cloud Storage Bucket, aby móc uzyskać do niej dostęp stamtąd:
cloudsql.instances.import
, storage.objects.get
cloudsql.instances.import
, storage.objects.get
Importuj bazę danych (nadpisz) z Cloud Storage Bucket:
cloudsql.databases.delete
cloudsql.databases.delete
Usuń bazę danych z instancji bazy danych:
Last updated