Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/taylorfinnell/awscr-s3
A Crystal shard for S3.
https://github.com/taylorfinnell/awscr-s3
aws crystal s3
Last synced: 8 days ago
JSON representation
A Crystal shard for S3.
- Host: GitHub
- URL: https://github.com/taylorfinnell/awscr-s3
- Owner: taylorfinnell
- License: mit
- Created: 2017-07-12T01:34:51.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-07-07T18:17:46.000Z (6 months ago)
- Last Synced: 2024-12-28T18:18:22.703Z (15 days ago)
- Topics: aws, crystal, s3
- Language: Crystal
- Homepage: https://taylorfinnell.github.io/awscr-s3/
- Size: 290 KB
- Stars: 81
- Watchers: 10
- Forks: 48
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-crystal - awscr-s3 - AWS S3 interface (Third-party APIs)
- awesome-crystal - awscr-s3 - AWS S3 interface (Third-party APIs)
- awesome-crystal - awscr-s3 - AWS S3 interface (Third-party APIs)
README
# awscr-s3
[![CI](https://github.com/taylorfinnell/awscr-s3/actions/workflows/ci.yml/badge.svg)](https://github.com/taylorfinnell/awscr-s3/actions/workflows/ci.yml)A Crystal shard for S3 and compatible services.
## Installation
Add this to your application's `shard.yml`:
```yaml
dependencies:
awscr-s3:
github: taylorfinnell/awscr-s3
```## Examples
[Examples](https://github.com/taylorfinnell/awscr-s3/tree/master/examples)
## Documentation
[Documentation](https://taylorfinnell.github.io/awscr-s3/)
## Usage
```crystal
require "awscr-s3"
```## **Creating a Client**
```crystal
client = Awscr::S3::Client.new("us-east-1", "key", "secret")
```For S3 compatible services, like DigitalOcean Spaces or Minio, you'll need to set a custom endpoint:
```crystal
client = Awscr::S3::Client.new("nyc3", "key", "secret", endpoint: "https://nyc3.digitaloceanspaces.com")
```If you wish you wish to you version 2 request signing you may specify the signer
```crystal
client = Awscr::S3::Client.new("us-east-1", "key", "secret", signer: :v2)
```## **List Buckets**
```crystal
resp = client.list_buckets
resp.buckets # => ["bucket1", "bucket2"]
```## **Delete a bucket**
```crystal
client = Client.new("region", "key", "secret")
resp = client.delete_bucket("test")
resp # => true
```## Create a bucket
```crystal
client = Client.new("region", "key", "secret")
resp = client.put_bucket("test")
resp # => true
```## **Put Object**
```crystal
resp = client.put_object("bucket_name", "object_key", "myobjectbody")
resp.etag # => ...
```You can also pass additional headers (e.g. metadata):
```crystal
client.put_object("bucket_name", "object_key", "myobjectbody", {"x-amz-meta-name" => "myobject"})
```## **Delete Object**
```crystal
resp = client.delete_object("bucket_name", "object_key")
resp # => true
```## **Check Bucket Existence**
```crystal
resp = client.head_bucket("bucket_name")
resp # => true
```Raises an exception if bucket does not exist.
## **Batch Delete Objects**
```crystal
resp = client.batch_delete("bucket_name", ["key1", "key2"])
resp.success? # => true
```## **Get Object**
```crystal
resp = client.get_object("bucket_name", "object_key")
resp.body # => myobjectbody# Or stream the object (recommended for large objects)
client.get_object("bucket_name", "object_key") do |obj|
IO.copy(obj.body_io, STDOUT) # => myobjectbody
end
```## **List Objects**
```crystal
client.list_objects("bucket_name").each do |resp|
p resp.contents.map(&.key)
end
```## **Upload a file**
```crystal
uploader = Awscr::S3::FileUploader.new(client)File.open(File.expand_path("myfile"), "r") do |file|
puts uploader.upload("bucket_name", "someobjectkey", file)
end
```You can also pass additional headers (e.g. metadata):
```crystal
uploader = Awscr::S3::FileUploader.new(client)File.open(File.expand_path("myfile"), "r") do |file|
puts uploader.upload("bucket_name", "someobjectkey", file, {"x-amz-meta-name" => "myobject"})
end
```## **Creating a `Presigned::Form`.**
```crystal
form = Awscr::S3::Presigned::Form.build("us-east-1", "access key", "secret key") do |form|
form.expiration(Time.unix(Time.now.to_unix + 1000))
form.condition("bucket", "mybucket")
form.condition("acl", "public-read")
form.condition("key", SecureRandom.uuid)
form.condition("Content-Type", "text/plain")
form.condition("success_action_status", "201")
end
```You may use version 2 request signing via
```crystal
form = Awscr::S3::Presigned::Form.build("us-east-1", "access key", "secret key", signer: :v2) do |form|
...
end
```**Converting the form to raw HTML (for browser uploads, etc).**
```crystal
puts form.to_html
```**Submitting the form.**
```crystal
data = IO::Memory.new("Hello, S3!")
form.submit(data)
```## **Creating a `Presigned::Url`.**
```crystal
options = Awscr::S3::Presigned::Url::Options.new(
aws_access_key: "key",
aws_secret_key: "secret",
region: "us-east-1",
object: "test.txt",
bucket: "mybucket",
additional_options: {
"Content-Type" => "image/png"
})url = Awscr::S3::Presigned::Url.new(options)
p url.for(:put)
```You may use version 2 request signing via
```crystal
options = Awscr::S3::Presigned::Url::Options.new(
aws_access_key: "key",
aws_secret_key: "secret",
region: "us-east-1",
object: "test.txt",
bucket: "mybucket",
signer: :v2
)
```