Skip to main content

S3 CLI Tool to execute basic commands

Project description

S3 Command Line Utility

Credentials

First of all, you will need to have your credentials ready. The following are needed (next to them are the names of the environmental variables associated to them):

  • Endpoint ENDPOINT
  • Access Key ACCESS_KEY
  • Secret Access Key SECRET_ACCESS_KEY
  • Bucket BUCKET
  • OPTIONALLY: if you have an HTTP prefix for accessing keys over a web browser you can add it with the HTTP_PREFIX variable

In order to avoid having to introduce your credentials after every command execution it is possible to store them as environmental variables. You can even do this temporarily setting a variables as export ENDPOINT_URL=MyURL. This way, your credentials will only be set for the current terminal.

Operations

The following operations are possible:

  • Listing all keys in a bucket
  • Listing keys according to a prefix in a bucket
  • Change key permissions to public-read
  • Upload any number of keys. Is Multithreaded.
  • Download any number of keys. Is Multithreaded.
  • Delete keys. Is Multithreaded.

Usage:

$ s3-tool [OPTIONS] COMMAND [ARGS]...

Options:

  • --install-completion: Install completion for the current shell.
  • --show-completion: Show completion for the current shell, to copy it or customize the installation.
  • --help: Show this message and exit.

Commands:

  • change-permissions: Takes any number of keys and changes their...
  • create-upload-list: Writes a text file of all files in a folder...
  • delete-key: USE WITH EXTREME CAUTION! Deletes a given key...
  • download: Downloads a key or series of keys
  • list-keys: Lists keys according to a given prefix
  • list-keys-v2: Lists keys using S3 client. Allows for using a delimiter to limit the output to "subfolders"
  • upload: Uploads a single file or multiple files.

s3-tool change-permissions

Takes any number of keys and changes their permissions to public-read

Usage:

$ s3-tool change-permissions [OPTIONS] ARGS...

Options:

  • --prefix-threads INTEGER: Sets the amount of prefixes that should be queried in parallel.
  • --changer-threads INTEGER: Sets the amount of threads used to change permissions for a given prefix.
  • -p, --permissions [private|public-read|public-read-write|authenticated-read|aws-exec-read|bucket-owner-read|bucket-owner-full-control]: Changes the keys permissions.
  • --help: Show this message and exit.

s3-tool create-upload-list

Writes a text file of all files in a folder with a given extension that can be used together with the upload command to upload multiple files at once

Usage:

$ s3-tool create-upload-list [OPTIONS] FILES_PATH FILE_EXTENSION

Options:

  • --output-path TEXT: Choose an output path. Else, the file will be written on the folder where the command is executed.
  • --help: Show this message and exit.

s3-tool delete-key

USE WITH EXTREME CAUTION! Deletes a given key or keys

Usage:

$ s3-tool delete-key [OPTIONS]

Options:

  • -f, --files TEXT: Keys to be deleted.
  • --prompt / --no-prompt: Display a prompt to confirm deletion.
  • --threads INTEGER: Set the amount of threads to delete keys in parallel. Disable the prompt if using this option.
  • --help: Show this message and exit.

s3-tool download

Downloads a key or series of keys

Usage:

$ s3-tool download [OPTIONS] DOWNLOAD_PATH

Options:

  • -f, --files TEXT: Either a file or files, or a text file containing paths to files separated by commas (,).
  • -r, --recursive TEXT: Recursively downloads a objects after a / delimiter.
  • -t, --threads INTEGER: Amount of threads used to download in parallel.
  • --help: Show this message and exit.

s3-tool list-keys

Lists keys according to a given prefix

Usage:

$ s3-tool list-keys [OPTIONS]

Options:

  • -p, --prefix TEXT: Prefix to look for keys.
  • -d, --delimiter TEXT: A delimiter is a character you use to group keys.
  • --max-keys, -mk INTEGER: Sets the maximum number of keys returned in the response. The response might contain fewer keys but will never contain more.
  • -hp, --http-prefix: Append HTTP URL Prefix to keys.
  • --all / --no-all: USE WITH CAUTION! If True, will fetch every key in the Bucket.
  • -l, --limit INTEGER: Limits the amount of keys returned.
  • -km, --key-methods [key|last_modified|size|owner]
  • --help: Show this message and exit.

s3-tool list-keys-v2

Lists keys using the S3 client rather than Resource (used for thelist-keys command). Allows the usage of a delimiter to limit the output to "subfolders". Only operation not possible is the checking of ACL Grants.

Usage:

$ s3-tool list-keys-v2 [OPTIONS]

Options:

  • -p, --prefix TEXT: Prefix to look for keys [default: source/]
  • -d, --delimiter TEXT: A delimiter is a character you use to group keys. [default: ]
  • --max-keys, -mk INTEGER: Sets the maximum number of keys returned in the response. The response might contain fewer keys but will never contain more. [default: 1000]
  • -hp, --http-prefix: Append HTTP URL Prefix to keys [default: False]
  • -km, --key-methods [key|last_modified|size|owner]
  • --help: Show this message and exit.

s3-tool upload

Uploads a single file or multiple files. Files need to have their absolute path. The last argument passed will be the upload path. Optionally, one can choose the amount of threads that should be used.

Usage:

$ s3-tool upload [OPTIONS] UPLOAD_PATH

Options:

  • -f, --files TEXT: Chose either a file or files with absolute path.
  • -uff, --upload-from-file TEXT: Upload using text file containing paths to files separated by commas (,).
  • --permissions TEXT: Sets the permission for the uploaded file. Options are: 'private' | 'public-read' | 'public-read-write' | 'authenticated-read' | 'aws-exec-read' | 'bucket-owner-read' | 'bucket-owner-full-control'
  • --worker-threads INTEGER: Amount of threads used to upload in parallel.
  • --help: Show this message and exit.

s3-tool move-object

Moves objects from one location to another within the same bucket.

Usage:

$ s3-tool move-object [OPTIONS] DESTINATION_PATH

Options:

  • -f, --files TEXT: Choose one or more objects you wish to move.
  • --permissions TEXT: Sets the permission for the copied object. Options are: 'private' | 'public-read' | 'public-read-write' | 'authenticated-read' | 'aws-exec-read' | 'bucket-owner-read' | 'bucket-owner-full-control'
  • -rn, --rename TEXT: Choose new object name. Destination path will have no effect but has to be input just the same.
  • --threads INTEGER: Amount of threads used to upload in parallel.
  • --help: Show this message and exit.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

s3_tool-0.3.6.tar.gz (10.3 kB view details)

Uploaded Source

Built Distribution

s3_tool-0.3.6-py3-none-any.whl (10.2 kB view details)

Uploaded Python 3

File details

Details for the file s3_tool-0.3.6.tar.gz.

File metadata

  • Download URL: s3_tool-0.3.6.tar.gz
  • Upload date:
  • Size: 10.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.11.3 Linux/6.4.9-1-MANJARO

File hashes

Hashes for s3_tool-0.3.6.tar.gz
Algorithm Hash digest
SHA256 b420243812bdb4e2273468a28688c494262ac5810ef81f4019cba9573b33916c
MD5 b1d62f7d27922b24f340b9edb9bccaa7
BLAKE2b-256 813be114806ccb7c7d40b66a2c7bbfd26a4b96a05430050280d18bd2827a6798

See more details on using hashes here.

File details

Details for the file s3_tool-0.3.6-py3-none-any.whl.

File metadata

  • Download URL: s3_tool-0.3.6-py3-none-any.whl
  • Upload date:
  • Size: 10.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.11.3 Linux/6.4.9-1-MANJARO

File hashes

Hashes for s3_tool-0.3.6-py3-none-any.whl
Algorithm Hash digest
SHA256 a55dc4c2997f823eb8a5172d55ece67e06dbfb29f35208be9167c130b8b809ec
MD5 55b748d839de9ac7d75bec8832e37daa
BLAKE2b-256 2eeace3a4543370c4b84f98eed7da71f9990a3c7c214b869d1c0b244c74f4af9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page