Method: googleapis.storage.v1.objects.insert

Stores a new object and metadata.

Arguments

Parameters
bucket

string

Required. Name of the bucket in which to store the new object. Overrides the provided object metadata's bucket value, if any.

contentEncoding

string

If set, sets the contentEncoding property of the final object to this value. Setting this parameter is equivalent to setting the contentEncoding metadata property. This can be useful when uploading an object with uploadType=media to indicate the encoding of the content being uploaded.

ifGenerationMatch

string (int64 format)

Makes the operation conditional on whether the object's current generation matches the given value. Setting to 0 makes the operation succeed only if there are no live versions of the object.

ifGenerationNotMatch

string (int64 format)

Makes the operation conditional on whether the object's current generation does not match the given value. If no live object exists, the precondition fails. Setting to 0 makes the operation succeed only if there is a live version of the object.

ifMetagenerationMatch

string (int64 format)

Makes the operation conditional on whether the object's current metageneration matches the given value.

ifMetagenerationNotMatch

string (int64 format)

Makes the operation conditional on whether the object's current metageneration does not match the given value.

kmsKeyName

string

Resource name of the Cloud KMS key, of the form projects/my-project/locations/global/keyRings/my-kr/cryptoKeys/my-key, that will be used to encrypt the object. Overrides the object metadata's kms_key_name value, if any.

name

string

Name of the object. Required when the object metadata is not otherwise provided. Overrides the object metadata's name value, if any. For information about how to URL encode object names to be path safe, see Encoding URI Path Parts.

predefinedAcl

enum

Apply a predefined set of access controls to this object.

Enum type. Can be one of the following:
authenticatedRead Object owner gets OWNER access, and allAuthenticatedUsers get READER access.
bucketOwnerFullControl Object owner gets OWNER access, and project team owners get OWNER access.
bucketOwnerRead Object owner gets OWNER access, and project team owners get READER access.
private Object owner gets OWNER access.
projectPrivate Object owner gets OWNER access, and project team members get access according to their roles.
publicRead Object owner gets OWNER access, and allUsers get READER access.
projection

enum

Set of properties to return. Defaults to noAcl, unless the object resource specifies the acl property, when it defaults to full.

Enum type. Can be one of the following:
full Include all properties.
noAcl Omit the owner, acl property.
userProject

string

The project to be billed for this request. Required for Requester Pays buckets.

body

object (Object)

Required.

Raised exceptions

Exceptions
ConnectionError In case of a network problem (such as DNS failure or refused connection).
HttpError If the response status is >= 400 (excluding 429 and 503).
TimeoutError If a long-running operation takes longer to finish than the specified timeout limit.
TypeError If an operation or function receives an argument of the wrong type.
ValueError If an operation or function receives an argument of the right type but an inappropriate value. For example, a negative timeout.

Response

If successful, the response contains an instance of Object.

Subworkflow snippet

Some fields might be optional or required. To identify required fields, refer to the API documentation.

YAML

- insert:
    call: googleapis.storage.v1.objects.insert
    args:
        bucket: ...
        contentEncoding: ...
        ifGenerationMatch: ...
        ifGenerationNotMatch: ...
        ifMetagenerationMatch: ...
        ifMetagenerationNotMatch: ...
        kmsKeyName: ...
        name: ...
        predefinedAcl: ...
        projection: ...
        userProject: ...
        body:
            acl: ...
            bucket: ...
            cacheControl: ...
            componentCount: ...
            contentDisposition: ...
            contentEncoding: ...
            contentLanguage: ...
            contentType: ...
            crc32c: ...
            customTime: ...
            customerEncryption:
                encryptionAlgorithm: ...
                keySha256: ...
            etag: ...
            eventBasedHold: ...
            generation: ...
            id: ...
            kind: ...
            kmsKeyName: ...
            md5Hash: ...
            mediaLink: ...
            metadata: ...
            metageneration: ...
            name: ...
            owner:
                entity: ...
                entityId: ...
            retentionExpirationTime: ...
            selfLink: ...
            size: ...
            storageClass: ...
            temporaryHold: ...
            timeCreated: ...
            timeDeleted: ...
            timeStorageClassUpdated: ...
            updated: ...
    result: insertResult

JSON

[
  {
    "insert": {
      "call": "googleapis.storage.v1.objects.insert",
      "args": {
        "bucket": "...",
        "contentEncoding": "...",
        "ifGenerationMatch": "...",
        "ifGenerationNotMatch": "...",
        "ifMetagenerationMatch": "...",
        "ifMetagenerationNotMatch": "...",
        "kmsKeyName": "...",
        "name": "...",
        "predefinedAcl": "...",
        "projection": "...",
        "userProject": "...",
        "body": {
          "acl": "...",
          "bucket": "...",
          "cacheControl": "...",
          "componentCount": "...",
          "contentDisposition": "...",
          "contentEncoding": "...",
          "contentLanguage": "...",
          "contentType": "...",
          "crc32c": "...",
          "customTime": "...",
          "customerEncryption": {
            "encryptionAlgorithm": "...",
            "keySha256": "..."
          },
          "etag": "...",
          "eventBasedHold": "...",
          "generation": "...",
          "id": "...",
          "kind": "...",
          "kmsKeyName": "...",
          "md5Hash": "...",
          "mediaLink": "...",
          "metadata": "...",
          "metageneration": "...",
          "name": "...",
          "owner": {
            "entity": "...",
            "entityId": "..."
          },
          "retentionExpirationTime": "...",
          "selfLink": "...",
          "size": "...",
          "storageClass": "...",
          "temporaryHold": "...",
          "timeCreated": "...",
          "timeDeleted": "...",
          "timeStorageClassUpdated": "...",
          "updated": "..."
        }
      },
      "result": "insertResult"
    }
  }
]