38 lines
724 B
Go
38 lines
724 B
Go
|
package s3
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"os"
|
||
|
|
||
|
"context"
|
||
|
|
||
|
goofys "github.com/kahing/goofys/api"
|
||
|
)
|
||
|
|
||
|
const defaultRegion = "us-east-1"
|
||
|
|
||
|
func goofysMount(bucket string, cr *Credentials, targetPath string) error {
|
||
|
cfg := &goofys.Config{
|
||
|
MountPoint: targetPath,
|
||
|
Endpoint: cr.Endpoint,
|
||
|
Region: cr.Region,
|
||
|
DirMode: 0755,
|
||
|
FileMode: 0644,
|
||
|
MountOptions: map[string]string{
|
||
|
"allow_other": "",
|
||
|
},
|
||
|
}
|
||
|
if cfg.Endpoint != "" {
|
||
|
cfg.Region = defaultRegion
|
||
|
}
|
||
|
os.Setenv("AWS_ACCESS_KEY_ID", cr.AccessKeyID)
|
||
|
os.Setenv("AWS_SECRET_ACCESS_KEY", cr.SecretAccessKey)
|
||
|
|
||
|
_, _, err := goofys.Mount(context.Background(), bucket, cfg)
|
||
|
|
||
|
if err != nil {
|
||
|
return fmt.Errorf("Error mounting via goofys: %s", err)
|
||
|
}
|
||
|
return nil
|
||
|
}
|