|
|
|
|
@ -1,7 +1,9 @@
|
|
|
|
|
package google
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"bytes"
|
|
|
|
|
"fmt"
|
|
|
|
|
"io"
|
|
|
|
|
"log"
|
|
|
|
|
"os"
|
|
|
|
|
|
|
|
|
|
@ -23,26 +25,39 @@ func resourceStorageBucketObject() *schema.Resource {
|
|
|
|
|
Required: true,
|
|
|
|
|
ForceNew: true,
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
"name": &schema.Schema{
|
|
|
|
|
Type: schema.TypeString,
|
|
|
|
|
Required: true,
|
|
|
|
|
ForceNew: true,
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
"source": &schema.Schema{
|
|
|
|
|
Type: schema.TypeString,
|
|
|
|
|
Required: true,
|
|
|
|
|
ForceNew: true,
|
|
|
|
|
Type: schema.TypeString,
|
|
|
|
|
Optional: true,
|
|
|
|
|
ForceNew: true,
|
|
|
|
|
ConflictsWith: []string{"content"},
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
"content": &schema.Schema{
|
|
|
|
|
Type: schema.TypeString,
|
|
|
|
|
Optional: true,
|
|
|
|
|
ForceNew: true,
|
|
|
|
|
ConflictsWith: []string{"source"},
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
"predefined_acl": &schema.Schema{
|
|
|
|
|
Type: schema.TypeString,
|
|
|
|
|
Deprecated: "Please use resource \"storage_object_acl.predefined_acl\" instead.",
|
|
|
|
|
Optional: true,
|
|
|
|
|
ForceNew: true,
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
"md5hash": &schema.Schema{
|
|
|
|
|
Type: schema.TypeString,
|
|
|
|
|
Computed: true,
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
"crc32c": &schema.Schema{
|
|
|
|
|
Type: schema.TypeString,
|
|
|
|
|
Computed: true,
|
|
|
|
|
@ -60,11 +75,18 @@ func resourceStorageBucketObjectCreate(d *schema.ResourceData, meta interface{})
|
|
|
|
|
|
|
|
|
|
bucket := d.Get("bucket").(string)
|
|
|
|
|
name := d.Get("name").(string)
|
|
|
|
|
source := d.Get("source").(string)
|
|
|
|
|
var media io.Reader
|
|
|
|
|
|
|
|
|
|
file, err := os.Open(source)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Error opening %s: %s", source, err)
|
|
|
|
|
if v, ok := d.GetOk("source"); ok {
|
|
|
|
|
err := error(nil)
|
|
|
|
|
media, err = os.Open(v.(string))
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
} else if v, ok := d.GetOk("content"); ok {
|
|
|
|
|
media = bytes.NewReader([]byte(v.(string)))
|
|
|
|
|
} else {
|
|
|
|
|
return fmt.Errorf("Error, either \"content\" or \"string\" must be specified")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
objectsService := storage.NewObjectsService(config.clientStorage)
|
|
|
|
|
@ -72,15 +94,15 @@ func resourceStorageBucketObjectCreate(d *schema.ResourceData, meta interface{})
|
|
|
|
|
|
|
|
|
|
insertCall := objectsService.Insert(bucket, object)
|
|
|
|
|
insertCall.Name(name)
|
|
|
|
|
insertCall.Media(file)
|
|
|
|
|
insertCall.Media(media)
|
|
|
|
|
if v, ok := d.GetOk("predefined_acl"); ok {
|
|
|
|
|
insertCall.PredefinedAcl(v.(string))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_, err = insertCall.Do()
|
|
|
|
|
_, err := insertCall.Do()
|
|
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Error uploading contents of object %s from %s: %s", name, source, err)
|
|
|
|
|
return fmt.Errorf("Error uploading object %s: %s", name, err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return resourceStorageBucketObjectRead(d, meta)
|
|
|
|
|
|