Skip to content

Instantly share code, notes, and snippets.

@eelkevanfoeken
Created October 21, 2021 14:11
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save eelkevanfoeken/8bfdafcaa9d8ff08c184fab1d87fced0 to your computer and use it in GitHub Desktop.
Save eelkevanfoeken/8bfdafcaa9d8ff08c184fab1d87fced0 to your computer and use it in GitHub Desktop.
A script to empty and delete buckets
#!/usr/bin/env bb
(require '[babashka.pods :as pods])
(pods/load-pod 'org.babashka/aws "0.0.6")
(require '[pod.babashka.aws :as aws])
(require '[pod.babashka.aws.credentials :as credentials])
(def region "us-east-1")
(def s3-client
(aws/client {:api :s3 :region region
:credentials-provider (credentials/basic-credentials-provider
{:access-key-id ""
:secret-access-key ""})}))
(defn list-objects [bucket]
(aws/invoke s3-client {:op :ListObjects
:request {:Bucket bucket}}))
(defn objects->keys [objects]
(map #(select-keys % [:Key]) (:Contents objects)))
(defn clear-s3-results
[bucket]
(loop [next-set (objects->keys (list-objects bucket))
deleted-objects []]
(if (pos? (count next-set))
(let [deleted (aws/invoke s3-client {:op :DeleteObjects
:request {:Bucket bucket
:Delete {:Objects next-set}}})]
(recur (objects->keys (list-objects bucket))
(apply conj deleted-objects (:Deleted deleted))))
deleted-objects)))
(defn delete-s3-bucket [bucket]
(aws/invoke s3-client {:op :DeleteBucket
:request {:Bucket bucket}}))
(defn empty-and-delete-bucket [bucket]
(clear-s3-results bucket)
(delete-s3-bucket bucket))
(defn bucket-names [buckets]
(map :Name buckets))
(defn empty-and-delete-buckets []
(let [{:keys [Buckets]} (aws/invoke s3-client {:op :ListBuckets})
bucket-names (bucket-names Buckets)]
(pmap
empty-and-delete-bucket
bucket-names)))
(empty-and-delete-buckets)
@borkdude
Copy link

Solution from Slack:

Yeah, in my gist I set the region in the client. But apparently, when getting the buckets with this client, it gives back buckets in other regions as well. If I then try to list object from a bucket outside that region this error occurs. The solution is to retrieve the region by calling GetBucketLocation and add that to the list objects request

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment