digitalocean/sample-functions-golang-presigned-url
Go
Captured source
source ↗GH
Source ↗published Jul 7, 2022seen 5dcaptured 8hhttp 200method plain
digitalocean/sample-functions-golang-presigned-url
Description: Creating a presigned url for DO's Spaces
Language: Go
Stars: 13
Forks: 9
Open issues: 0
Created: 2022-07-07T17:27:34Z
Pushed: 2022-08-04T22:38:49Z
Default branch: main
Fork: no
Archived: no
README:
Sample Function: Go "Presigned URL"
Introduction
This repository contains a sample presigned URL function written in Go. You are able to choose to get a presigned URL to upload a file to a DigitalOcean Space or to download a file from a DigitalOcean Space. You can deploy it on DigitalOcean's App Platform as a Serverless Function component. Documentation is available at https://docs.digitalocean.com/products/functions.
Requirements
- You need a DigitalOcean account. If you don't already have one, you can sign up at https://cloud.digitalocean.com/registrations/new.
- You need a DigitalOcean Space. If you don't have one, you can create one at https://www.digitalocean.com/products/spaces.
- You need to add your
SPACES_KEY,SPACES_SECRET,BUCKET, andREGIONto the.envfile to connect to Spaces API as well as your bucket. - To deploy from the command line, you will need the DigitalOcean `doctl` CLI.
Deploying the Function
# clone this repo git clone https://github.com/digitalocean/sample-functions-golang-presigned-url
# deploy the project, using a remote build so that compiled executable matched runtime environment
> doctl serverless deploy sample-functions-golang-presigned-url --remote-build
Deploying 'sample-functions-golang-presigned-url'
to namespace 'fn-...'
on host 'https://faas-...'
Submitted action 'url' for remote building and deployment in runtime go:default (id: ...)
Deployed functions ('doctl sls fn get --url' for URL):
- presign/urlUsing the Function
doctl serverless functions invoke presign/url -p filename:new-file.txt type:GET
{
"body": "{presigned url}"
}To get a presigned url using curl:
curl -X PUT -H 'Content-Type: application/json' {your-DO-app-url} -d '{"filename":"{filename}", "type":"GET or PUT"}'To Upload or Download a file using curl:
curl -X PUT -d 'The contents of the file.' "{url}"Learn More
You can learn more about Functions and App Platform integration in the official App Platform Documentation.
Excerpt shown — open the source for the full document.