Documentation

Overview

Package pubsub provides access to the Cloud Pub/Sub API.

This package is DEPRECATED. Use package cloud.google.com/go/pubsub instead.

For product documentation, see: https://cloud.google.com/pubsub/docs

Creating a client

Usage example:

import "google.golang.org/api/pubsub/v1beta2"
...
ctx := context.Background()
pubsubService, err := pubsub.NewService(ctx)

In this example, Google Application Default Credentials are used for authentication.

For information on how to create and obtain Application Default Credentials, see https://developers.google.com/identity/protocols/application-default-credentials.

Other authentication options

By default, all available scopes (see "Constants") are used to authenticate. To restrict scopes, use option.WithScopes:

pubsubService, err := pubsub.NewService(ctx, option.WithScopes(pubsub.PubsubScope))

To use an API key for authentication (note: some APIs do not support API keys), use option.WithAPIKey:

pubsubService, err := pubsub.NewService(ctx, option.WithAPIKey("AIza..."))

To use an OAuth token (e.g., a user token obtained via a three-legged OAuth flow), use option.WithTokenSource:

config := &oauth2.Config{...}
// ...
token, err := config.Exchange(ctx, ...)
pubsubService, err := pubsub.NewService(ctx, option.WithTokenSource(config.TokenSource(ctx, token)))

See https://godoc.org/google.golang.org/api/option/ for details on options.

Index

Constants

View Source
const (
	// View and manage your data across Google Cloud Platform services
	CloudPlatformScope = "https://www.googleapis.com/auth/cloud-platform"

	// View and manage Pub/Sub topics and subscriptions
	PubsubScope = "https://www.googleapis.com/auth/pubsub"
)

    OAuth2 scopes used by this API.

    Variables

    This section is empty.

    Functions

    This section is empty.

    Types

    type AcknowledgeRequest

    type AcknowledgeRequest struct {
    	// AckIds: The acknowledgment ID for the messages being acknowledged
    	// that was returned
    	// by the Pub/Sub system in the `Pull` response. Must not be empty.
    	AckIds []string `json:"ackIds,omitempty"`
    
    	// ForceSendFields is a list of field names (e.g. "AckIds") to
    	// unconditionally include in API requests. By default, fields with
    	// empty values are omitted from API requests. However, any non-pointer,
    	// non-interface field appearing in ForceSendFields will be sent to the
    	// server regardless of whether the field is empty or not. This may be
    	// used to include empty fields in Patch requests.
    	ForceSendFields []string `json:"-"`
    
    	// NullFields is a list of field names (e.g. "AckIds") to include in API
    	// requests with the JSON null value. By default, fields with empty
    	// values are omitted from API requests. However, any field with an
    	// empty value appearing in NullFields will be sent to the server as
    	// null. It is an error if a field in this list has a non-empty value.
    	// This may be used to include null fields in Patch requests.
    	NullFields []string `json:"-"`
    }

      AcknowledgeRequest: Request for the Acknowledge method.

      func (*AcknowledgeRequest) MarshalJSON

      func (s *AcknowledgeRequest) MarshalJSON() ([]byte, error)

      type Binding

      type Binding struct {
      	// Condition: The condition that is associated with this binding.
      	// NOTE: An unsatisfied condition will not allow user access via
      	// current
      	// binding. Different bindings, including their conditions, are
      	// examined
      	// independently.
      	Condition *Expr `json:"condition,omitempty"`
      
      	// Members: Specifies the identities requesting access for a Cloud
      	// Platform resource.
      	// `members` can have the following values:
      	//
      	// * `allUsers`: A special identifier that represents anyone who is
      	//    on the internet; with or without a Google account.
      	//
      	// * `allAuthenticatedUsers`: A special identifier that represents
      	// anyone
      	//    who is authenticated with a Google account or a service
      	// account.
      	//
      	// * `user:{emailid}`: An email address that represents a specific
      	// Google
      	//    account. For example, `alice@example.com` .
      	//
      	//
      	// * `serviceAccount:{emailid}`: An email address that represents a
      	// service
      	//    account. For example,
      	// `my-other-app@appspot.gserviceaccount.com`.
      	//
      	// * `group:{emailid}`: An email address that represents a Google
      	// group.
      	//    For example, `admins@example.com`.
      	//
      	// * `deleted:user:{emailid}?uid={uniqueid}`: An email address (plus
      	// unique
      	//    identifier) representing a user that has been recently deleted.
      	// For
      	//    example, `alice@example.com?uid=123456789012345678901`. If the
      	// user is
      	//    recovered, this value reverts to `user:{emailid}` and the
      	// recovered user
      	//    retains the role in the binding.
      	//
      	// * `deleted:serviceAccount:{emailid}?uid={uniqueid}`: An email address
      	// (plus
      	//    unique identifier) representing a service account that has been
      	// recently
      	//    deleted. For example,
      	//
      	// `my-other-app@appspot.gserviceaccount.com?uid=123456789012345678901`.
      	//
      	//    If the service account is undeleted, this value reverts to
      	//    `serviceAccount:{emailid}` and the undeleted service account
      	// retains the
      	//    role in the binding.
      	//
      	// * `deleted:group:{emailid}?uid={uniqueid}`: An email address (plus
      	// unique
      	//    identifier) representing a Google group that has been recently
      	//    deleted. For example,
      	// `admins@example.com?uid=123456789012345678901`. If
      	//    the group is recovered, this value reverts to `group:{emailid}`
      	// and the
      	//    recovered group retains the role in the binding.
      	//
      	//
      	// * `domain:{domain}`: The G Suite domain (primary) that represents all
      	// the
      	//    users of that domain. For example, `google.com` or
      	// `example.com`.
      	//
      	//
      	Members []string `json:"members,omitempty"`
      
      	// Role: Role that is assigned to `members`.
      	// For example, `roles/viewer`, `roles/editor`, or `roles/owner`.
      	Role string `json:"role,omitempty"`
      
      	// ForceSendFields is a list of field names (e.g. "Condition") to
      	// unconditionally include in API requests. By default, fields with
      	// empty values are omitted from API requests. However, any non-pointer,
      	// non-interface field appearing in ForceSendFields will be sent to the
      	// server regardless of whether the field is empty or not. This may be
      	// used to include empty fields in Patch requests.
      	ForceSendFields []string `json:"-"`
      
      	// NullFields is a list of field names (e.g. "Condition") to include in
      	// API requests with the JSON null value. By default, fields with empty
      	// values are omitted from API requests. However, any field with an
      	// empty value appearing in NullFields will be sent to the server as
      	// null. It is an error if a field in this list has a non-empty value.
      	// This may be used to include null fields in Patch requests.
      	NullFields []string `json:"-"`
      }

        Binding: Associates `members` with a `role`.

        func (*Binding) MarshalJSON

        func (s *Binding) MarshalJSON() ([]byte, error)

        type Empty

        type Empty struct {
        	// ServerResponse contains the HTTP response code and headers from the
        	// server.
        	googleapi.ServerResponse `json:"-"`
        }

          Empty: A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance:

          service Foo {
            rpc Bar(google.protobuf.Empty) returns
          

          (google.protobuf.Empty);

          }
          

          The JSON representation for `Empty` is empty JSON object `{}`.

          type Expr

          type Expr struct {
          	// Description: An optional description of the expression. This is a
          	// longer text which
          	// describes the expression, e.g. when hovered over it in a UI.
          	Description string `json:"description,omitempty"`
          
          	// Expression: Textual representation of an expression in
          	// Common Expression Language syntax.
          	//
          	// The application context of the containing message determines
          	// which
          	// well-known feature set of CEL is supported.
          	Expression string `json:"expression,omitempty"`
          
          	// Location: An optional string indicating the location of the
          	// expression for error
          	// reporting, e.g. a file name and a position in the file.
          	Location string `json:"location,omitempty"`
          
          	// Title: An optional title for the expression, i.e. a short string
          	// describing
          	// its purpose. This can be used e.g. in UIs which allow to enter
          	// the
          	// expression.
          	Title string `json:"title,omitempty"`
          
          	// ForceSendFields is a list of field names (e.g. "Description") to
          	// unconditionally include in API requests. By default, fields with
          	// empty values are omitted from API requests. However, any non-pointer,
          	// non-interface field appearing in ForceSendFields will be sent to the
          	// server regardless of whether the field is empty or not. This may be
          	// used to include empty fields in Patch requests.
          	ForceSendFields []string `json:"-"`
          
          	// NullFields is a list of field names (e.g. "Description") to include
          	// in API requests with the JSON null value. By default, fields with
          	// empty values are omitted from API requests. However, any field with
          	// an empty value appearing in NullFields will be sent to the server as
          	// null. It is an error if a field in this list has a non-empty value.
          	// This may be used to include null fields in Patch requests.
          	NullFields []string `json:"-"`
          }

            Expr: Represents an expression text. Example:

            title: "User account presence"
            description: "Determines whether the request has a user account"
            expression: "size(request.user) > 0"
            

            func (*Expr) MarshalJSON

            func (s *Expr) MarshalJSON() ([]byte, error)

            type ListSubscriptionsResponse

            type ListSubscriptionsResponse struct {
            	// NextPageToken: If not empty, indicates that there may be more
            	// subscriptions that match
            	// the request; this value should be passed in a
            	// new
            	// `ListSubscriptionsRequest` to get more subscriptions.
            	NextPageToken string `json:"nextPageToken,omitempty"`
            
            	// Subscriptions: The subscriptions that match the request.
            	Subscriptions []*Subscription `json:"subscriptions,omitempty"`
            
            	// ServerResponse contains the HTTP response code and headers from the
            	// server.
            	googleapi.ServerResponse `json:"-"`
            
            	// ForceSendFields is a list of field names (e.g. "NextPageToken") to
            	// unconditionally include in API requests. By default, fields with
            	// empty values are omitted from API requests. However, any non-pointer,
            	// non-interface field appearing in ForceSendFields will be sent to the
            	// server regardless of whether the field is empty or not. This may be
            	// used to include empty fields in Patch requests.
            	ForceSendFields []string `json:"-"`
            
            	// NullFields is a list of field names (e.g. "NextPageToken") to include
            	// in API requests with the JSON null value. By default, fields with
            	// empty values are omitted from API requests. However, any field with
            	// an empty value appearing in NullFields will be sent to the server as
            	// null. It is an error if a field in this list has a non-empty value.
            	// This may be used to include null fields in Patch requests.
            	NullFields []string `json:"-"`
            }

              ListSubscriptionsResponse: Response for the `ListSubscriptions` method.

              func (*ListSubscriptionsResponse) MarshalJSON

              func (s *ListSubscriptionsResponse) MarshalJSON() ([]byte, error)

              type ListTopicSubscriptionsResponse

              type ListTopicSubscriptionsResponse struct {
              	// NextPageToken: If not empty, indicates that there may be more
              	// subscriptions that match
              	// the request; this value should be passed in a
              	// new
              	// `ListTopicSubscriptionsRequest` to get more subscriptions.
              	NextPageToken string `json:"nextPageToken,omitempty"`
              
              	// Subscriptions: The names of the subscriptions that match the request.
              	Subscriptions []string `json:"subscriptions,omitempty"`
              
              	// ServerResponse contains the HTTP response code and headers from the
              	// server.
              	googleapi.ServerResponse `json:"-"`
              
              	// ForceSendFields is a list of field names (e.g. "NextPageToken") to
              	// unconditionally include in API requests. By default, fields with
              	// empty values are omitted from API requests. However, any non-pointer,
              	// non-interface field appearing in ForceSendFields will be sent to the
              	// server regardless of whether the field is empty or not. This may be
              	// used to include empty fields in Patch requests.
              	ForceSendFields []string `json:"-"`
              
              	// NullFields is a list of field names (e.g. "NextPageToken") to include
              	// in API requests with the JSON null value. By default, fields with
              	// empty values are omitted from API requests. However, any field with
              	// an empty value appearing in NullFields will be sent to the server as
              	// null. It is an error if a field in this list has a non-empty value.
              	// This may be used to include null fields in Patch requests.
              	NullFields []string `json:"-"`
              }

                ListTopicSubscriptionsResponse: Response for the `ListTopicSubscriptions` method.

                func (*ListTopicSubscriptionsResponse) MarshalJSON

                func (s *ListTopicSubscriptionsResponse) MarshalJSON() ([]byte, error)

                type ListTopicsResponse

                type ListTopicsResponse struct {
                	// NextPageToken: If not empty, indicates that there may be more topics
                	// that match the
                	// request; this value should be passed in a new `ListTopicsRequest`.
                	NextPageToken string `json:"nextPageToken,omitempty"`
                
                	// Topics: The resulting topics.
                	Topics []*Topic `json:"topics,omitempty"`
                
                	// ServerResponse contains the HTTP response code and headers from the
                	// server.
                	googleapi.ServerResponse `json:"-"`
                
                	// ForceSendFields is a list of field names (e.g. "NextPageToken") to
                	// unconditionally include in API requests. By default, fields with
                	// empty values are omitted from API requests. However, any non-pointer,
                	// non-interface field appearing in ForceSendFields will be sent to the
                	// server regardless of whether the field is empty or not. This may be
                	// used to include empty fields in Patch requests.
                	ForceSendFields []string `json:"-"`
                
                	// NullFields is a list of field names (e.g. "NextPageToken") to include
                	// in API requests with the JSON null value. By default, fields with
                	// empty values are omitted from API requests. However, any field with
                	// an empty value appearing in NullFields will be sent to the server as
                	// null. It is an error if a field in this list has a non-empty value.
                	// This may be used to include null fields in Patch requests.
                	NullFields []string `json:"-"`
                }

                  ListTopicsResponse: Response for the `ListTopics` method.

                  func (*ListTopicsResponse) MarshalJSON

                  func (s *ListTopicsResponse) MarshalJSON() ([]byte, error)

                  type ModifyAckDeadlineRequest

                  type ModifyAckDeadlineRequest struct {
                  	// AckDeadlineSeconds: The new ack deadline with respect to the time
                  	// this request was sent to
                  	// the Pub/Sub system. Must be >= 0. For example, if the value is 10,
                  	// the new
                  	// ack deadline will expire 10 seconds after the `ModifyAckDeadline`
                  	// call
                  	// was made. Specifying zero may immediately make the message available
                  	// for
                  	// another pull request.
                  	AckDeadlineSeconds int64 `json:"ackDeadlineSeconds,omitempty"`
                  
                  	// AckId: The acknowledgment ID. Either this or ack_ids must be
                  	// populated, but not
                  	// both.
                  	AckId string `json:"ackId,omitempty"`
                  
                  	// AckIds: List of acknowledgment IDs.
                  	AckIds []string `json:"ackIds,omitempty"`
                  
                  	// ForceSendFields is a list of field names (e.g. "AckDeadlineSeconds")
                  	// to unconditionally include in API requests. By default, fields with
                  	// empty values are omitted from API requests. However, any non-pointer,
                  	// non-interface field appearing in ForceSendFields will be sent to the
                  	// server regardless of whether the field is empty or not. This may be
                  	// used to include empty fields in Patch requests.
                  	ForceSendFields []string `json:"-"`
                  
                  	// NullFields is a list of field names (e.g. "AckDeadlineSeconds") to
                  	// include in API requests with the JSON null value. By default, fields
                  	// with empty values are omitted from API requests. However, any field
                  	// with an empty value appearing in NullFields will be sent to the
                  	// server as null. It is an error if a field in this list has a
                  	// non-empty value. This may be used to include null fields in Patch
                  	// requests.
                  	NullFields []string `json:"-"`
                  }

                    ModifyAckDeadlineRequest: Request for the ModifyAckDeadline method.

                    func (*ModifyAckDeadlineRequest) MarshalJSON

                    func (s *ModifyAckDeadlineRequest) MarshalJSON() ([]byte, error)

                    type ModifyPushConfigRequest

                    type ModifyPushConfigRequest struct {
                    	// PushConfig: The push configuration for future deliveries.
                    	//
                    	// An empty `pushConfig` indicates that the Pub/Sub system should
                    	// stop pushing messages from the given subscription and allow
                    	// messages to be pulled and acknowledged - effectively pausing
                    	// the subscription if `Pull` is not called.
                    	PushConfig *PushConfig `json:"pushConfig,omitempty"`
                    
                    	// ForceSendFields is a list of field names (e.g. "PushConfig") to
                    	// unconditionally include in API requests. By default, fields with
                    	// empty values are omitted from API requests. However, any non-pointer,
                    	// non-interface field appearing in ForceSendFields will be sent to the
                    	// server regardless of whether the field is empty or not. This may be
                    	// used to include empty fields in Patch requests.
                    	ForceSendFields []string `json:"-"`
                    
                    	// NullFields is a list of field names (e.g. "PushConfig") to include in
                    	// API requests with the JSON null value. By default, fields with empty
                    	// values are omitted from API requests. However, any field with an
                    	// empty value appearing in NullFields will be sent to the server as
                    	// null. It is an error if a field in this list has a non-empty value.
                    	// This may be used to include null fields in Patch requests.
                    	NullFields []string `json:"-"`
                    }

                      ModifyPushConfigRequest: Request for the ModifyPushConfig method.

                      func (*ModifyPushConfigRequest) MarshalJSON

                      func (s *ModifyPushConfigRequest) MarshalJSON() ([]byte, error)

                      type OidcToken

                      type OidcToken struct {
                      	// Audience: Audience to be used when generating OIDC token. The
                      	// audience claim
                      	// identifies the recipients that the JWT is intended for. The
                      	// audience
                      	// value is a single case-sensitive string. Having multiple values
                      	// (array)
                      	// for the audience field is not supported. More info about the OIDC
                      	// JWT
                      	// token audience here:
                      	// https://tools.ietf.org/html/rfc7519#section-4.1.3
                      	// Note: if not specified, the Push endpoint URL will be used.
                      	Audience string `json:"audience,omitempty"`
                      
                      	// ServiceAccountEmail: [Service
                      	// account
                      	// email](https://cloud.google.com/iam/docs/service-accounts)
                      	// to be used for generating the OIDC token. The caller
                      	// (for
                      	// CreateSubscription, UpdateSubscription, and ModifyPushConfig RPCs)
                      	// must
                      	// have the iam.serviceAccounts.actAs permission for the service
                      	// account.
                      	ServiceAccountEmail string `json:"serviceAccountEmail,omitempty"`
                      
                      	// ForceSendFields is a list of field names (e.g. "Audience") to
                      	// unconditionally include in API requests. By default, fields with
                      	// empty values are omitted from API requests. However, any non-pointer,
                      	// non-interface field appearing in ForceSendFields will be sent to the
                      	// server regardless of whether the field is empty or not. This may be
                      	// used to include empty fields in Patch requests.
                      	ForceSendFields []string `json:"-"`
                      
                      	// NullFields is a list of field names (e.g. "Audience") to include in
                      	// API requests with the JSON null value. By default, fields with empty
                      	// values are omitted from API requests. However, any field with an
                      	// empty value appearing in NullFields will be sent to the server as
                      	// null. It is an error if a field in this list has a non-empty value.
                      	// This may be used to include null fields in Patch requests.
                      	NullFields []string `json:"-"`
                      }

                        OidcToken: Contains information needed for generating an [OpenID Connect token](https://developers.google.com/identity/protocols/OpenID Connect).

                        func (*OidcToken) MarshalJSON

                        func (s *OidcToken) MarshalJSON() ([]byte, error)

                        type Policy

                        type Policy struct {
                        	// Bindings: Associates a list of `members` to a `role`. Optionally, may
                        	// specify a
                        	// `condition` that determines how and when the `bindings` are applied.
                        	// Each
                        	// of the `bindings` must contain at least one member.
                        	Bindings []*Binding `json:"bindings,omitempty"`
                        
                        	// Etag: `etag` is used for optimistic concurrency control as a way to
                        	// help
                        	// prevent simultaneous updates of a policy from overwriting each
                        	// other.
                        	// It is strongly suggested that systems make use of the `etag` in
                        	// the
                        	// read-modify-write cycle to perform policy updates in order to avoid
                        	// race
                        	// conditions: An `etag` is returned in the response to `getIamPolicy`,
                        	// and
                        	// systems are expected to put that etag in the request to
                        	// `setIamPolicy` to
                        	// ensure that their change will be applied to the same version of the
                        	// policy.
                        	//
                        	// **Important:** If you use IAM Conditions, you must include the `etag`
                        	// field
                        	// whenever you call `setIamPolicy`. If you omit this field, then IAM
                        	// allows
                        	// you to overwrite a version `3` policy with a version `1` policy, and
                        	// all of
                        	// the conditions in the version `3` policy are lost.
                        	Etag string `json:"etag,omitempty"`
                        
                        	// Version: Specifies the format of the policy.
                        	//
                        	// Valid values are `0`, `1`, and `3`. Requests that specify an invalid
                        	// value
                        	// are rejected.
                        	//
                        	// Any operation that affects conditional role bindings must specify
                        	// version
                        	// `3`. This requirement applies to the following operations:
                        	//
                        	// * Getting a policy that includes a conditional role binding
                        	// * Adding a conditional role binding to a policy
                        	// * Changing a conditional role binding in a policy
                        	// * Removing any role binding, with or without a condition, from a
                        	// policy
                        	//   that includes conditions
                        	//
                        	// **Important:** If you use IAM Conditions, you must include the `etag`
                        	// field
                        	// whenever you call `setIamPolicy`. If you omit this field, then IAM
                        	// allows
                        	// you to overwrite a version `3` policy with a version `1` policy, and
                        	// all of
                        	// the conditions in the version `3` policy are lost.
                        	//
                        	// If a policy does not include any conditions, operations on that
                        	// policy may
                        	// specify any valid version or leave the field unset.
                        	Version int64 `json:"version,omitempty"`
                        
                        	// ServerResponse contains the HTTP response code and headers from the
                        	// server.
                        	googleapi.ServerResponse `json:"-"`
                        
                        	// ForceSendFields is a list of field names (e.g. "Bindings") to
                        	// unconditionally include in API requests. By default, fields with
                        	// empty values are omitted from API requests. However, any non-pointer,
                        	// non-interface field appearing in ForceSendFields will be sent to the
                        	// server regardless of whether the field is empty or not. This may be
                        	// used to include empty fields in Patch requests.
                        	ForceSendFields []string `json:"-"`
                        
                        	// NullFields is a list of field names (e.g. "Bindings") to include in
                        	// API requests with the JSON null value. By default, fields with empty
                        	// values are omitted from API requests. However, any field with an
                        	// empty value appearing in NullFields will be sent to the server as
                        	// null. It is an error if a field in this list has a non-empty value.
                        	// This may be used to include null fields in Patch requests.
                        	NullFields []string `json:"-"`
                        }

                          Policy: An Identity and Access Management (IAM) policy, which specifies access controls for Google Cloud resources.

                          A `Policy` is a collection of `bindings`. A `binding` binds one or more `members` to a single `role`. Members can be user accounts, service accounts, Google groups, and domains (such as G Suite). A `role` is a named list of permissions; each `role` can be an IAM predefined role or a user-created custom role.

                          Optionally, a `binding` can specify a `condition`, which is a logical expression that allows access to a resource only if the expression evaluates to `true`. A condition can add constraints based on attributes of the request, the resource, or both.

                          **JSON example:**

                          {
                            "bindings": [
                              {
                                "role": "roles/resourcemanager.organizationAdmin",
                                "members": [
                                  "user:mike@example.com",
                                  "group:admins@example.com",
                                  "domain:google.com",
                          

                          "serviceAccount:my-project-id@appspot.gserviceaccount.com"

                            ]
                          },
                          {
                            "role": "roles/resourcemanager.organizationViewer",
                            "members": ["user:eve@example.com"],
                            "condition": {
                              "title": "expirable access",
                              "description": "Does not grant access after Sep 2020",
                              "expression": "request.time <
                          

                          timestamp('2020-10-01T00:00:00.000Z')",

                                }
                              }
                            ],
                            "etag": "BwWWja0YfJA=",
                            "version": 3
                          }
                          

                          **YAML example:**

                          bindings:
                          - members:
                            - user:mike@example.com
                            - group:admins@example.com
                            - domain:google.com
                            - serviceAccount:my-project-id@appspot.gserviceaccount.com
                            role: roles/resourcemanager.organizationAdmin
                          - members:
                            - user:eve@example.com
                            role: roles/resourcemanager.organizationViewer
                            condition:
                              title: expirable access
                              description: Does not grant access after Sep 2020
                              expression: request.time <
                          

                          timestamp('2020-10-01T00:00:00.000Z')

                          - etag: BwWWja0YfJA=
                          - version: 3
                          

                          For a description of IAM and its features, see the [IAM documentation](https://cloud.google.com/iam/docs/).

                          func (*Policy) MarshalJSON

                          func (s *Policy) MarshalJSON() ([]byte, error)

                          type ProjectsService

                          type ProjectsService struct {
                          	Subscriptions *ProjectsSubscriptionsService
                          
                          	Topics *ProjectsTopicsService
                          	// contains filtered or unexported fields
                          }

                          func NewProjectsService

                          func NewProjectsService(s *Service) *ProjectsService

                          type ProjectsSubscriptionsAcknowledgeCall

                          type ProjectsSubscriptionsAcknowledgeCall struct {
                          	// contains filtered or unexported fields
                          }

                          func (*ProjectsSubscriptionsAcknowledgeCall) Context

                            Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                            func (*ProjectsSubscriptionsAcknowledgeCall) Do

                              Do executes the "pubsub.projects.subscriptions.acknowledge" call. Exactly one of *Empty or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Empty.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                              func (*ProjectsSubscriptionsAcknowledgeCall) Fields

                                Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                func (*ProjectsSubscriptionsAcknowledgeCall) Header

                                  Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                  type ProjectsSubscriptionsCreateCall

                                  type ProjectsSubscriptionsCreateCall struct {
                                  	// contains filtered or unexported fields
                                  }

                                  func (*ProjectsSubscriptionsCreateCall) Context

                                    Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                    func (*ProjectsSubscriptionsCreateCall) Do

                                      Do executes the "pubsub.projects.subscriptions.create" call. Exactly one of *Subscription or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Subscription.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                      func (*ProjectsSubscriptionsCreateCall) Fields

                                        Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                        func (*ProjectsSubscriptionsCreateCall) Header

                                          Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                          type ProjectsSubscriptionsDeleteCall

                                          type ProjectsSubscriptionsDeleteCall struct {
                                          	// contains filtered or unexported fields
                                          }

                                          func (*ProjectsSubscriptionsDeleteCall) Context

                                            Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                            func (*ProjectsSubscriptionsDeleteCall) Do

                                              Do executes the "pubsub.projects.subscriptions.delete" call. Exactly one of *Empty or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Empty.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                              func (*ProjectsSubscriptionsDeleteCall) Fields

                                                Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                func (*ProjectsSubscriptionsDeleteCall) Header

                                                  Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                  type ProjectsSubscriptionsGetCall

                                                  type ProjectsSubscriptionsGetCall struct {
                                                  	// contains filtered or unexported fields
                                                  }

                                                  func (*ProjectsSubscriptionsGetCall) Context

                                                    Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                    func (*ProjectsSubscriptionsGetCall) Do

                                                      Do executes the "pubsub.projects.subscriptions.get" call. Exactly one of *Subscription or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Subscription.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                      func (*ProjectsSubscriptionsGetCall) Fields

                                                        Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                        func (*ProjectsSubscriptionsGetCall) Header

                                                          Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                          func (*ProjectsSubscriptionsGetCall) IfNoneMatch

                                                            IfNoneMatch sets the optional parameter which makes the operation fail if the object's ETag matches the given value. This is useful for getting updates only after the object has changed since the last request. Use googleapi.IsNotModified to check whether the response error from Do is the result of In-None-Match.

                                                            type ProjectsSubscriptionsGetIamPolicyCall

                                                            type ProjectsSubscriptionsGetIamPolicyCall struct {
                                                            	// contains filtered or unexported fields
                                                            }

                                                            func (*ProjectsSubscriptionsGetIamPolicyCall) Context

                                                              Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                              func (*ProjectsSubscriptionsGetIamPolicyCall) Do

                                                                Do executes the "pubsub.projects.subscriptions.getIamPolicy" call. Exactly one of *Policy or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Policy.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                func (*ProjectsSubscriptionsGetIamPolicyCall) Fields

                                                                  Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                  func (*ProjectsSubscriptionsGetIamPolicyCall) Header

                                                                    Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                    func (*ProjectsSubscriptionsGetIamPolicyCall) IfNoneMatch

                                                                      IfNoneMatch sets the optional parameter which makes the operation fail if the object's ETag matches the given value. This is useful for getting updates only after the object has changed since the last request. Use googleapi.IsNotModified to check whether the response error from Do is the result of In-None-Match.

                                                                      func (*ProjectsSubscriptionsGetIamPolicyCall) OptionsRequestedPolicyVersion

                                                                      func (c *ProjectsSubscriptionsGetIamPolicyCall) OptionsRequestedPolicyVersion(optionsRequestedPolicyVersion int64) *ProjectsSubscriptionsGetIamPolicyCall

                                                                        OptionsRequestedPolicyVersion sets the optional parameter "options.requestedPolicyVersion": The policy format version to be returned.

                                                                        Valid values are 0, 1, and 3. Requests specifying an invalid value will be rejected.

                                                                        Requests for policies with any conditional bindings must specify version 3. Policies without any conditional bindings may specify any valid value or leave the field unset.

                                                                        type ProjectsSubscriptionsListCall

                                                                        type ProjectsSubscriptionsListCall struct {
                                                                        	// contains filtered or unexported fields
                                                                        }

                                                                        func (*ProjectsSubscriptionsListCall) Context

                                                                          Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                          func (*ProjectsSubscriptionsListCall) Do

                                                                            Do executes the "pubsub.projects.subscriptions.list" call. Exactly one of *ListSubscriptionsResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *ListSubscriptionsResponse.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                            func (*ProjectsSubscriptionsListCall) Fields

                                                                              Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                              func (*ProjectsSubscriptionsListCall) Header

                                                                                Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                func (*ProjectsSubscriptionsListCall) IfNoneMatch

                                                                                  IfNoneMatch sets the optional parameter which makes the operation fail if the object's ETag matches the given value. This is useful for getting updates only after the object has changed since the last request. Use googleapi.IsNotModified to check whether the response error from Do is the result of In-None-Match.

                                                                                  func (*ProjectsSubscriptionsListCall) PageSize

                                                                                    PageSize sets the optional parameter "pageSize": Maximum number of subscriptions to return.

                                                                                    func (*ProjectsSubscriptionsListCall) PageToken

                                                                                      PageToken sets the optional parameter "pageToken": The value returned by the last `ListSubscriptionsResponse`; indicates that this is a continuation of a prior `ListSubscriptions` call, and that the system should return the next page of data.

                                                                                      func (*ProjectsSubscriptionsListCall) Pages

                                                                                        Pages invokes f for each page of results. A non-nil error returned from f will halt the iteration. The provided context supersedes any context provided to the Context method.

                                                                                        type ProjectsSubscriptionsModifyAckDeadlineCall

                                                                                        type ProjectsSubscriptionsModifyAckDeadlineCall struct {
                                                                                        	// contains filtered or unexported fields
                                                                                        }

                                                                                        func (*ProjectsSubscriptionsModifyAckDeadlineCall) Context

                                                                                          Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                                          func (*ProjectsSubscriptionsModifyAckDeadlineCall) Do

                                                                                            Do executes the "pubsub.projects.subscriptions.modifyAckDeadline" call. Exactly one of *Empty or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Empty.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                                            func (*ProjectsSubscriptionsModifyAckDeadlineCall) Fields

                                                                                              Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                              func (*ProjectsSubscriptionsModifyAckDeadlineCall) Header

                                                                                                Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                type ProjectsSubscriptionsModifyPushConfigCall

                                                                                                type ProjectsSubscriptionsModifyPushConfigCall struct {
                                                                                                	// contains filtered or unexported fields
                                                                                                }

                                                                                                func (*ProjectsSubscriptionsModifyPushConfigCall) Context

                                                                                                  Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                                                  func (*ProjectsSubscriptionsModifyPushConfigCall) Do

                                                                                                    Do executes the "pubsub.projects.subscriptions.modifyPushConfig" call. Exactly one of *Empty or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Empty.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                                                    func (*ProjectsSubscriptionsModifyPushConfigCall) Fields

                                                                                                      Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                                      func (*ProjectsSubscriptionsModifyPushConfigCall) Header

                                                                                                        Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                        type ProjectsSubscriptionsPullCall

                                                                                                        type ProjectsSubscriptionsPullCall struct {
                                                                                                        	// contains filtered or unexported fields
                                                                                                        }

                                                                                                        func (*ProjectsSubscriptionsPullCall) Context

                                                                                                          Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                                                          func (*ProjectsSubscriptionsPullCall) Do

                                                                                                            Do executes the "pubsub.projects.subscriptions.pull" call. Exactly one of *PullResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *PullResponse.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                                                            func (*ProjectsSubscriptionsPullCall) Fields

                                                                                                              Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                                              func (*ProjectsSubscriptionsPullCall) Header

                                                                                                                Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                                type ProjectsSubscriptionsService

                                                                                                                type ProjectsSubscriptionsService struct {
                                                                                                                	// contains filtered or unexported fields
                                                                                                                }

                                                                                                                func NewProjectsSubscriptionsService

                                                                                                                func NewProjectsSubscriptionsService(s *Service) *ProjectsSubscriptionsService

                                                                                                                func (*ProjectsSubscriptionsService) Acknowledge

                                                                                                                func (r *ProjectsSubscriptionsService) Acknowledge(subscription string, acknowledgerequest *AcknowledgeRequest) *ProjectsSubscriptionsAcknowledgeCall

                                                                                                                  Acknowledge: Acknowledges the messages associated with the `ack_ids` in the `AcknowledgeRequest`. The Pub/Sub system can remove the relevant messages from the subscription.

                                                                                                                  Acknowledging a message whose ack deadline has expired may succeed, but such a message may be redelivered later. Acknowledging a message more than once will not result in an error.

                                                                                                                  func (*ProjectsSubscriptionsService) Create

                                                                                                                    Create: Creates a subscription to a given topic. If the subscription already exists, returns `ALREADY_EXISTS`. If the corresponding topic doesn't exist, returns `NOT_FOUND`.

                                                                                                                    If the name is not provided in the request, the server will assign a random name for this subscription on the same project as the topic. Note that for REST API requests, you must specify a name.

                                                                                                                    func (*ProjectsSubscriptionsService) Delete

                                                                                                                      Delete: Deletes an existing subscription. All pending messages in the subscription are immediately dropped. Calls to `Pull` after deletion will return `NOT_FOUND`. After a subscription is deleted, a new one may be created with the same name, but the new one has no association with the old subscription, or its topic unless the same topic is specified.

                                                                                                                      func (*ProjectsSubscriptionsService) Get

                                                                                                                        Get: Gets the configuration details of a subscription.

                                                                                                                        func (*ProjectsSubscriptionsService) GetIamPolicy

                                                                                                                          GetIamPolicy: Gets the access control policy for a resource. Returns an empty policy if the resource exists and does not have a policy set.

                                                                                                                          func (*ProjectsSubscriptionsService) List

                                                                                                                            List: Lists matching subscriptions.

                                                                                                                            func (*ProjectsSubscriptionsService) ModifyAckDeadline

                                                                                                                            func (r *ProjectsSubscriptionsService) ModifyAckDeadline(subscription string, modifyackdeadlinerequest *ModifyAckDeadlineRequest) *ProjectsSubscriptionsModifyAckDeadlineCall

                                                                                                                              ModifyAckDeadline: Modifies the ack deadline for a specific message. This method is useful to indicate that more time is needed to process a message by the subscriber, or to make the message available for redelivery if the processing was interrupted. Note that this does not modify the subscription-level `ackDeadlineSeconds` used for subsequent messages.

                                                                                                                              func (*ProjectsSubscriptionsService) ModifyPushConfig

                                                                                                                              func (r *ProjectsSubscriptionsService) ModifyPushConfig(subscription string, modifypushconfigrequest *ModifyPushConfigRequest) *ProjectsSubscriptionsModifyPushConfigCall

                                                                                                                                ModifyPushConfig: Modifies the `PushConfig` for a specified subscription.

                                                                                                                                This may be used to change a push subscription to a pull one (signified by an empty `PushConfig`) or vice versa, or change the endpoint URL and other attributes of a push subscription. Messages will accumulate for delivery continuously through the call regardless of changes to the `PushConfig`.

                                                                                                                                func (*ProjectsSubscriptionsService) Pull

                                                                                                                                  Pull: Pulls messages from the server. Returns an empty list if there are no messages available in the backlog. The server may return `UNAVAILABLE` if there are too many concurrent pull requests pending for the given subscription.

                                                                                                                                  func (*ProjectsSubscriptionsService) SetIamPolicy

                                                                                                                                  func (r *ProjectsSubscriptionsService) SetIamPolicy(resource string, setiampolicyrequest *SetIamPolicyRequest) *ProjectsSubscriptionsSetIamPolicyCall

                                                                                                                                    SetIamPolicy: Sets the access control policy on the specified resource. Replaces any existing policy.

                                                                                                                                    Can return Public Errors: NOT_FOUND, INVALID_ARGUMENT and PERMISSION_DENIED

                                                                                                                                    func (*ProjectsSubscriptionsService) TestIamPermissions

                                                                                                                                    func (r *ProjectsSubscriptionsService) TestIamPermissions(resource string, testiampermissionsrequest *TestIamPermissionsRequest) *ProjectsSubscriptionsTestIamPermissionsCall

                                                                                                                                      TestIamPermissions: Returns permissions that a caller has on the specified resource. If the resource does not exist, this will return an empty set of permissions, not a NOT_FOUND error.

                                                                                                                                      Note: This operation is designed to be used for building permission-aware UIs and command-line tools, not for authorization checking. This operation may "fail open" without warning.

                                                                                                                                      type ProjectsSubscriptionsSetIamPolicyCall

                                                                                                                                      type ProjectsSubscriptionsSetIamPolicyCall struct {
                                                                                                                                      	// contains filtered or unexported fields
                                                                                                                                      }

                                                                                                                                      func (*ProjectsSubscriptionsSetIamPolicyCall) Context

                                                                                                                                        Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                                                                                        func (*ProjectsSubscriptionsSetIamPolicyCall) Do

                                                                                                                                          Do executes the "pubsub.projects.subscriptions.setIamPolicy" call. Exactly one of *Policy or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Policy.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                                                                                          func (*ProjectsSubscriptionsSetIamPolicyCall) Fields

                                                                                                                                            Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                                                                            func (*ProjectsSubscriptionsSetIamPolicyCall) Header

                                                                                                                                              Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                                                              type ProjectsSubscriptionsTestIamPermissionsCall

                                                                                                                                              type ProjectsSubscriptionsTestIamPermissionsCall struct {
                                                                                                                                              	// contains filtered or unexported fields
                                                                                                                                              }

                                                                                                                                              func (*ProjectsSubscriptionsTestIamPermissionsCall) Context

                                                                                                                                                Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                                                                                                func (*ProjectsSubscriptionsTestIamPermissionsCall) Do

                                                                                                                                                  Do executes the "pubsub.projects.subscriptions.testIamPermissions" call. Exactly one of *TestIamPermissionsResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *TestIamPermissionsResponse.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                                                                                                  func (*ProjectsSubscriptionsTestIamPermissionsCall) Fields

                                                                                                                                                    Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                                                                                    func (*ProjectsSubscriptionsTestIamPermissionsCall) Header

                                                                                                                                                      Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                                                                      type ProjectsTopicsCreateCall

                                                                                                                                                      type ProjectsTopicsCreateCall struct {
                                                                                                                                                      	// contains filtered or unexported fields
                                                                                                                                                      }

                                                                                                                                                      func (*ProjectsTopicsCreateCall) Context

                                                                                                                                                        Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                                                                                                        func (*ProjectsTopicsCreateCall) Do

                                                                                                                                                          Do executes the "pubsub.projects.topics.create" call. Exactly one of *Topic or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Topic.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                                                                                                          func (*ProjectsTopicsCreateCall) Fields

                                                                                                                                                            Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                                                                                            func (*ProjectsTopicsCreateCall) Header

                                                                                                                                                            func (c *ProjectsTopicsCreateCall) Header() http.Header

                                                                                                                                                              Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                                                                              type ProjectsTopicsDeleteCall

                                                                                                                                                              type ProjectsTopicsDeleteCall struct {
                                                                                                                                                              	// contains filtered or unexported fields
                                                                                                                                                              }

                                                                                                                                                              func (*ProjectsTopicsDeleteCall) Context

                                                                                                                                                                Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                                                                                                                func (*ProjectsTopicsDeleteCall) Do

                                                                                                                                                                  Do executes the "pubsub.projects.topics.delete" call. Exactly one of *Empty or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Empty.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                                                                                                                  func (*ProjectsTopicsDeleteCall) Fields

                                                                                                                                                                    Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                                                                                                    func (*ProjectsTopicsDeleteCall) Header

                                                                                                                                                                    func (c *ProjectsTopicsDeleteCall) Header() http.Header

                                                                                                                                                                      Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                                                                                      type ProjectsTopicsGetCall

                                                                                                                                                                      type ProjectsTopicsGetCall struct {
                                                                                                                                                                      	// contains filtered or unexported fields
                                                                                                                                                                      }

                                                                                                                                                                      func (*ProjectsTopicsGetCall) Context

                                                                                                                                                                        Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                                                                                                                        func (*ProjectsTopicsGetCall) Do

                                                                                                                                                                          Do executes the "pubsub.projects.topics.get" call. Exactly one of *Topic or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Topic.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                                                                                                                          func (*ProjectsTopicsGetCall) Fields

                                                                                                                                                                            Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                                                                                                            func (*ProjectsTopicsGetCall) Header

                                                                                                                                                                            func (c *ProjectsTopicsGetCall) Header() http.Header

                                                                                                                                                                              Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                                                                                              func (*ProjectsTopicsGetCall) IfNoneMatch

                                                                                                                                                                              func (c *ProjectsTopicsGetCall) IfNoneMatch(entityTag string) *ProjectsTopicsGetCall

                                                                                                                                                                                IfNoneMatch sets the optional parameter which makes the operation fail if the object's ETag matches the given value. This is useful for getting updates only after the object has changed since the last request. Use googleapi.IsNotModified to check whether the response error from Do is the result of In-None-Match.

                                                                                                                                                                                type ProjectsTopicsGetIamPolicyCall

                                                                                                                                                                                type ProjectsTopicsGetIamPolicyCall struct {
                                                                                                                                                                                	// contains filtered or unexported fields
                                                                                                                                                                                }

                                                                                                                                                                                func (*ProjectsTopicsGetIamPolicyCall) Context

                                                                                                                                                                                  Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                                                                                                                                  func (*ProjectsTopicsGetIamPolicyCall) Do

                                                                                                                                                                                    Do executes the "pubsub.projects.topics.getIamPolicy" call. Exactly one of *Policy or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Policy.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                                                                                                                                    func (*ProjectsTopicsGetIamPolicyCall) Fields

                                                                                                                                                                                      Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                                                                                                                      func (*ProjectsTopicsGetIamPolicyCall) Header

                                                                                                                                                                                        Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                                                                                                        func (*ProjectsTopicsGetIamPolicyCall) IfNoneMatch

                                                                                                                                                                                          IfNoneMatch sets the optional parameter which makes the operation fail if the object's ETag matches the given value. This is useful for getting updates only after the object has changed since the last request. Use googleapi.IsNotModified to check whether the response error from Do is the result of In-None-Match.

                                                                                                                                                                                          func (*ProjectsTopicsGetIamPolicyCall) OptionsRequestedPolicyVersion

                                                                                                                                                                                          func (c *ProjectsTopicsGetIamPolicyCall) OptionsRequestedPolicyVersion(optionsRequestedPolicyVersion int64) *ProjectsTopicsGetIamPolicyCall

                                                                                                                                                                                            OptionsRequestedPolicyVersion sets the optional parameter "options.requestedPolicyVersion": The policy format version to be returned.

                                                                                                                                                                                            Valid values are 0, 1, and 3. Requests specifying an invalid value will be rejected.

                                                                                                                                                                                            Requests for policies with any conditional bindings must specify version 3. Policies without any conditional bindings may specify any valid value or leave the field unset.

                                                                                                                                                                                            type ProjectsTopicsListCall

                                                                                                                                                                                            type ProjectsTopicsListCall struct {
                                                                                                                                                                                            	// contains filtered or unexported fields
                                                                                                                                                                                            }

                                                                                                                                                                                            func (*ProjectsTopicsListCall) Context

                                                                                                                                                                                              Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                                                                                                                                              func (*ProjectsTopicsListCall) Do

                                                                                                                                                                                                Do executes the "pubsub.projects.topics.list" call. Exactly one of *ListTopicsResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *ListTopicsResponse.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                                                                                                                                                func (*ProjectsTopicsListCall) Fields

                                                                                                                                                                                                  Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                                                                                                                                  func (*ProjectsTopicsListCall) Header

                                                                                                                                                                                                  func (c *ProjectsTopicsListCall) Header() http.Header

                                                                                                                                                                                                    Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                                                                                                                    func (*ProjectsTopicsListCall) IfNoneMatch

                                                                                                                                                                                                    func (c *ProjectsTopicsListCall) IfNoneMatch(entityTag string) *ProjectsTopicsListCall

                                                                                                                                                                                                      IfNoneMatch sets the optional parameter which makes the operation fail if the object's ETag matches the given value. This is useful for getting updates only after the object has changed since the last request. Use googleapi.IsNotModified to check whether the response error from Do is the result of In-None-Match.

                                                                                                                                                                                                      func (*ProjectsTopicsListCall) PageSize

                                                                                                                                                                                                      func (c *ProjectsTopicsListCall) PageSize(pageSize int64) *ProjectsTopicsListCall

                                                                                                                                                                                                        PageSize sets the optional parameter "pageSize": Maximum number of topics to return.

                                                                                                                                                                                                        func (*ProjectsTopicsListCall) PageToken

                                                                                                                                                                                                        func (c *ProjectsTopicsListCall) PageToken(pageToken string) *ProjectsTopicsListCall

                                                                                                                                                                                                          PageToken sets the optional parameter "pageToken": The value returned by the last `ListTopicsResponse`; indicates that this is a continuation of a prior `ListTopics` call, and that the system should return the next page of data.

                                                                                                                                                                                                          func (*ProjectsTopicsListCall) Pages

                                                                                                                                                                                                            Pages invokes f for each page of results. A non-nil error returned from f will halt the iteration. The provided context supersedes any context provided to the Context method.

                                                                                                                                                                                                            type ProjectsTopicsPublishCall

                                                                                                                                                                                                            type ProjectsTopicsPublishCall struct {
                                                                                                                                                                                                            	// contains filtered or unexported fields
                                                                                                                                                                                                            }

                                                                                                                                                                                                            func (*ProjectsTopicsPublishCall) Context

                                                                                                                                                                                                              Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                                                                                                                                                              func (*ProjectsTopicsPublishCall) Do

                                                                                                                                                                                                                Do executes the "pubsub.projects.topics.publish" call. Exactly one of *PublishResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *PublishResponse.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                                                                                                                                                                func (*ProjectsTopicsPublishCall) Fields

                                                                                                                                                                                                                  Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                                                                                                                                                  func (*ProjectsTopicsPublishCall) Header

                                                                                                                                                                                                                    Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                                                                                                                                    type ProjectsTopicsService

                                                                                                                                                                                                                    type ProjectsTopicsService struct {
                                                                                                                                                                                                                    	Subscriptions *ProjectsTopicsSubscriptionsService
                                                                                                                                                                                                                    	// contains filtered or unexported fields
                                                                                                                                                                                                                    }

                                                                                                                                                                                                                    func NewProjectsTopicsService

                                                                                                                                                                                                                    func NewProjectsTopicsService(s *Service) *ProjectsTopicsService

                                                                                                                                                                                                                    func (*ProjectsTopicsService) Create

                                                                                                                                                                                                                      Create: Creates the given topic with the given name.

                                                                                                                                                                                                                      func (*ProjectsTopicsService) Delete

                                                                                                                                                                                                                        Delete: Deletes the topic with the given name. Returns `NOT_FOUND` if the topic does not exist. After a topic is deleted, a new topic may be created with the same name; this is an entirely new topic with none of the old configuration or subscriptions. Existing subscriptions to this topic are not deleted, but their `topic` field is set to `_deleted-topic_`.

                                                                                                                                                                                                                        func (*ProjectsTopicsService) Get

                                                                                                                                                                                                                          Get: Gets the configuration of a topic.

                                                                                                                                                                                                                          func (*ProjectsTopicsService) GetIamPolicy

                                                                                                                                                                                                                          func (r *ProjectsTopicsService) GetIamPolicy(resource string) *ProjectsTopicsGetIamPolicyCall

                                                                                                                                                                                                                            GetIamPolicy: Gets the access control policy for a resource. Returns an empty policy if the resource exists and does not have a policy set.

                                                                                                                                                                                                                            func (*ProjectsTopicsService) List

                                                                                                                                                                                                                              List: Lists matching topics.

                                                                                                                                                                                                                              func (*ProjectsTopicsService) Publish

                                                                                                                                                                                                                              func (r *ProjectsTopicsService) Publish(topic string, publishrequest *PublishRequest) *ProjectsTopicsPublishCall

                                                                                                                                                                                                                                Publish: Adds one or more messages to the topic. Returns `NOT_FOUND` if the topic does not exist. The message payload must not be empty; it must contain

                                                                                                                                                                                                                                either a non-empty data field, or at least one attribute.
                                                                                                                                                                                                                                

                                                                                                                                                                                                                                func (*ProjectsTopicsService) SetIamPolicy

                                                                                                                                                                                                                                func (r *ProjectsTopicsService) SetIamPolicy(resource string, setiampolicyrequest *SetIamPolicyRequest) *ProjectsTopicsSetIamPolicyCall

                                                                                                                                                                                                                                  SetIamPolicy: Sets the access control policy on the specified resource. Replaces any existing policy.

                                                                                                                                                                                                                                  Can return Public Errors: NOT_FOUND, INVALID_ARGUMENT and PERMISSION_DENIED

                                                                                                                                                                                                                                  func (*ProjectsTopicsService) TestIamPermissions

                                                                                                                                                                                                                                  func (r *ProjectsTopicsService) TestIamPermissions(resource string, testiampermissionsrequest *TestIamPermissionsRequest) *ProjectsTopicsTestIamPermissionsCall

                                                                                                                                                                                                                                    TestIamPermissions: Returns permissions that a caller has on the specified resource. If the resource does not exist, this will return an empty set of permissions, not a NOT_FOUND error.

                                                                                                                                                                                                                                    Note: This operation is designed to be used for building permission-aware UIs and command-line tools, not for authorization checking. This operation may "fail open" without warning.

                                                                                                                                                                                                                                    type ProjectsTopicsSetIamPolicyCall

                                                                                                                                                                                                                                    type ProjectsTopicsSetIamPolicyCall struct {
                                                                                                                                                                                                                                    	// contains filtered or unexported fields
                                                                                                                                                                                                                                    }

                                                                                                                                                                                                                                    func (*ProjectsTopicsSetIamPolicyCall) Context

                                                                                                                                                                                                                                      Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                                                                                                                                                                                      func (*ProjectsTopicsSetIamPolicyCall) Do

                                                                                                                                                                                                                                        Do executes the "pubsub.projects.topics.setIamPolicy" call. Exactly one of *Policy or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *Policy.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                                                                                                                                                                                        func (*ProjectsTopicsSetIamPolicyCall) Fields

                                                                                                                                                                                                                                          Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                                                                                                                                                                          func (*ProjectsTopicsSetIamPolicyCall) Header

                                                                                                                                                                                                                                            Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                                                                                                                                                            type ProjectsTopicsSubscriptionsListCall

                                                                                                                                                                                                                                            type ProjectsTopicsSubscriptionsListCall struct {
                                                                                                                                                                                                                                            	// contains filtered or unexported fields
                                                                                                                                                                                                                                            }

                                                                                                                                                                                                                                            func (*ProjectsTopicsSubscriptionsListCall) Context

                                                                                                                                                                                                                                              Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                                                                                                                                                                                              func (*ProjectsTopicsSubscriptionsListCall) Do

                                                                                                                                                                                                                                                Do executes the "pubsub.projects.topics.subscriptions.list" call. Exactly one of *ListTopicSubscriptionsResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *ListTopicSubscriptionsResponse.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                                                                                                                                                                                                func (*ProjectsTopicsSubscriptionsListCall) Fields

                                                                                                                                                                                                                                                  Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                                                                                                                                                                                  func (*ProjectsTopicsSubscriptionsListCall) Header

                                                                                                                                                                                                                                                    Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                                                                                                                                                                    func (*ProjectsTopicsSubscriptionsListCall) IfNoneMatch

                                                                                                                                                                                                                                                      IfNoneMatch sets the optional parameter which makes the operation fail if the object's ETag matches the given value. This is useful for getting updates only after the object has changed since the last request. Use googleapi.IsNotModified to check whether the response error from Do is the result of In-None-Match.

                                                                                                                                                                                                                                                      func (*ProjectsTopicsSubscriptionsListCall) PageSize

                                                                                                                                                                                                                                                        PageSize sets the optional parameter "pageSize": Maximum number of subscription names to return.

                                                                                                                                                                                                                                                        func (*ProjectsTopicsSubscriptionsListCall) PageToken

                                                                                                                                                                                                                                                          PageToken sets the optional parameter "pageToken": The value returned by the last `ListTopicSubscriptionsResponse`; indicates that this is a continuation of a prior `ListTopicSubscriptions` call, and that the system should return the next page of data.

                                                                                                                                                                                                                                                          func (*ProjectsTopicsSubscriptionsListCall) Pages

                                                                                                                                                                                                                                                            Pages invokes f for each page of results. A non-nil error returned from f will halt the iteration. The provided context supersedes any context provided to the Context method.

                                                                                                                                                                                                                                                            type ProjectsTopicsSubscriptionsService

                                                                                                                                                                                                                                                            type ProjectsTopicsSubscriptionsService struct {
                                                                                                                                                                                                                                                            	// contains filtered or unexported fields
                                                                                                                                                                                                                                                            }

                                                                                                                                                                                                                                                            func NewProjectsTopicsSubscriptionsService

                                                                                                                                                                                                                                                            func NewProjectsTopicsSubscriptionsService(s *Service) *ProjectsTopicsSubscriptionsService

                                                                                                                                                                                                                                                            func (*ProjectsTopicsSubscriptionsService) List

                                                                                                                                                                                                                                                              List: Lists the name of the subscriptions for this topic.

                                                                                                                                                                                                                                                              type ProjectsTopicsTestIamPermissionsCall

                                                                                                                                                                                                                                                              type ProjectsTopicsTestIamPermissionsCall struct {
                                                                                                                                                                                                                                                              	// contains filtered or unexported fields
                                                                                                                                                                                                                                                              }

                                                                                                                                                                                                                                                              func (*ProjectsTopicsTestIamPermissionsCall) Context

                                                                                                                                                                                                                                                                Context sets the context to be used in this call's Do method. Any pending HTTP request will be aborted if the provided context is canceled.

                                                                                                                                                                                                                                                                func (*ProjectsTopicsTestIamPermissionsCall) Do

                                                                                                                                                                                                                                                                  Do executes the "pubsub.projects.topics.testIamPermissions" call. Exactly one of *TestIamPermissionsResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *TestIamPermissionsResponse.ServerResponse.Header or (if a response was returned at all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check whether the returned error was because http.StatusNotModified was returned.

                                                                                                                                                                                                                                                                  func (*ProjectsTopicsTestIamPermissionsCall) Fields

                                                                                                                                                                                                                                                                    Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                                                                                                                                                                                                    func (*ProjectsTopicsTestIamPermissionsCall) Header

                                                                                                                                                                                                                                                                      Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                                                                                                                                                                                      type PublishRequest

                                                                                                                                                                                                                                                                      type PublishRequest struct {
                                                                                                                                                                                                                                                                      	// Messages: The messages to publish.
                                                                                                                                                                                                                                                                      	Messages []*PubsubMessage `json:"messages,omitempty"`
                                                                                                                                                                                                                                                                      
                                                                                                                                                                                                                                                                      	// ForceSendFields is a list of field names (e.g. "Messages") to
                                                                                                                                                                                                                                                                      	// unconditionally include in API requests. By default, fields with
                                                                                                                                                                                                                                                                      	// empty values are omitted from API requests. However, any non-pointer,
                                                                                                                                                                                                                                                                      	// non-interface field appearing in ForceSendFields will be sent to the
                                                                                                                                                                                                                                                                      	// server regardless of whether the field is empty or not. This may be
                                                                                                                                                                                                                                                                      	// used to include empty fields in Patch requests.
                                                                                                                                                                                                                                                                      	ForceSendFields []string `json:"-"`
                                                                                                                                                                                                                                                                      
                                                                                                                                                                                                                                                                      	// NullFields is a list of field names (e.g. "Messages") to include in
                                                                                                                                                                                                                                                                      	// API requests with the JSON null value. By default, fields with empty
                                                                                                                                                                                                                                                                      	// values are omitted from API requests. However, any field with an
                                                                                                                                                                                                                                                                      	// empty value appearing in NullFields will be sent to the server as
                                                                                                                                                                                                                                                                      	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                                                                                                                                                                      	// This may be used to include null fields in Patch requests.
                                                                                                                                                                                                                                                                      	NullFields []string `json:"-"`
                                                                                                                                                                                                                                                                      }

                                                                                                                                                                                                                                                                        PublishRequest: Request for the Publish method.

                                                                                                                                                                                                                                                                        func (*PublishRequest) MarshalJSON

                                                                                                                                                                                                                                                                        func (s *PublishRequest) MarshalJSON() ([]byte, error)

                                                                                                                                                                                                                                                                        type PublishResponse

                                                                                                                                                                                                                                                                        type PublishResponse struct {
                                                                                                                                                                                                                                                                        	// MessageIds: The server-assigned ID of each published message, in the
                                                                                                                                                                                                                                                                        	// same order as
                                                                                                                                                                                                                                                                        	// the messages in the request. IDs are guaranteed to be unique
                                                                                                                                                                                                                                                                        	// within
                                                                                                                                                                                                                                                                        	// the topic.
                                                                                                                                                                                                                                                                        	MessageIds []string `json:"messageIds,omitempty"`
                                                                                                                                                                                                                                                                        
                                                                                                                                                                                                                                                                        	// ServerResponse contains the HTTP response code and headers from the
                                                                                                                                                                                                                                                                        	// server.
                                                                                                                                                                                                                                                                        	googleapi.ServerResponse `json:"-"`
                                                                                                                                                                                                                                                                        
                                                                                                                                                                                                                                                                        	// ForceSendFields is a list of field names (e.g. "MessageIds") to
                                                                                                                                                                                                                                                                        	// unconditionally include in API requests. By default, fields with
                                                                                                                                                                                                                                                                        	// empty values are omitted from API requests. However, any non-pointer,
                                                                                                                                                                                                                                                                        	// non-interface field appearing in ForceSendFields will be sent to the
                                                                                                                                                                                                                                                                        	// server regardless of whether the field is empty or not. This may be
                                                                                                                                                                                                                                                                        	// used to include empty fields in Patch requests.
                                                                                                                                                                                                                                                                        	ForceSendFields []string `json:"-"`
                                                                                                                                                                                                                                                                        
                                                                                                                                                                                                                                                                        	// NullFields is a list of field names (e.g. "MessageIds") to include in
                                                                                                                                                                                                                                                                        	// API requests with the JSON null value. By default, fields with empty
                                                                                                                                                                                                                                                                        	// values are omitted from API requests. However, any field with an
                                                                                                                                                                                                                                                                        	// empty value appearing in NullFields will be sent to the server as
                                                                                                                                                                                                                                                                        	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                                                                                                                                                                        	// This may be used to include null fields in Patch requests.
                                                                                                                                                                                                                                                                        	NullFields []string `json:"-"`
                                                                                                                                                                                                                                                                        }

                                                                                                                                                                                                                                                                          PublishResponse: Response for the `Publish` method.

                                                                                                                                                                                                                                                                          func (*PublishResponse) MarshalJSON

                                                                                                                                                                                                                                                                          func (s *PublishResponse) MarshalJSON() ([]byte, error)

                                                                                                                                                                                                                                                                          type PubsubMessage

                                                                                                                                                                                                                                                                          type PubsubMessage struct {
                                                                                                                                                                                                                                                                          	// Attributes: Optional attributes for this message.
                                                                                                                                                                                                                                                                          	Attributes map[string]string `json:"attributes,omitempty"`
                                                                                                                                                                                                                                                                          
                                                                                                                                                                                                                                                                          	// Data: The message payload. For JSON requests, the value of this field
                                                                                                                                                                                                                                                                          	// must be
                                                                                                                                                                                                                                                                          	// [base64-encoded](https://tools.ietf.org/html/rfc4648).
                                                                                                                                                                                                                                                                          	Data string `json:"data,omitempty"`
                                                                                                                                                                                                                                                                          
                                                                                                                                                                                                                                                                          	// MessageId: ID of this message, assigned by the server when the
                                                                                                                                                                                                                                                                          	// message is published.
                                                                                                                                                                                                                                                                          	// Guaranteed to be unique within the topic. This value may be read by
                                                                                                                                                                                                                                                                          	// a
                                                                                                                                                                                                                                                                          	// subscriber that receives a `PubsubMessage` via a `Pull` call or a
                                                                                                                                                                                                                                                                          	// push
                                                                                                                                                                                                                                                                          	// delivery. It must not be populated by the publisher in a `Publish`
                                                                                                                                                                                                                                                                          	// call.
                                                                                                                                                                                                                                                                          	MessageId string `json:"messageId,omitempty"`
                                                                                                                                                                                                                                                                          
                                                                                                                                                                                                                                                                          	// PublishTime: The time at which the message was published, populated
                                                                                                                                                                                                                                                                          	// by the server when
                                                                                                                                                                                                                                                                          	// it receives the `Publish` call. It must not be populated by
                                                                                                                                                                                                                                                                          	// the
                                                                                                                                                                                                                                                                          	// publisher in a `Publish` call.
                                                                                                                                                                                                                                                                          	PublishTime string `json:"publishTime,omitempty"`
                                                                                                                                                                                                                                                                          
                                                                                                                                                                                                                                                                          	// ForceSendFields is a list of field names (e.g. "Attributes") to
                                                                                                                                                                                                                                                                          	// unconditionally include in API requests. By default, fields with
                                                                                                                                                                                                                                                                          	// empty values are omitted from API requests. However, any non-pointer,
                                                                                                                                                                                                                                                                          	// non-interface field appearing in ForceSendFields will be sent to the
                                                                                                                                                                                                                                                                          	// server regardless of whether the field is empty or not. This may be
                                                                                                                                                                                                                                                                          	// used to include empty fields in Patch requests.
                                                                                                                                                                                                                                                                          	ForceSendFields []string `json:"-"`
                                                                                                                                                                                                                                                                          
                                                                                                                                                                                                                                                                          	// NullFields is a list of field names (e.g. "Attributes") to include in
                                                                                                                                                                                                                                                                          	// API requests with the JSON null value. By default, fields with empty
                                                                                                                                                                                                                                                                          	// values are omitted from API requests. However, any field with an
                                                                                                                                                                                                                                                                          	// empty value appearing in NullFields will be sent to the server as
                                                                                                                                                                                                                                                                          	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                                                                                                                                                                          	// This may be used to include null fields in Patch requests.
                                                                                                                                                                                                                                                                          	NullFields []string `json:"-"`
                                                                                                                                                                                                                                                                          }

                                                                                                                                                                                                                                                                            PubsubMessage: A message data and its attributes. The message payload must not be empty; it must contain either a non-empty data field, or at least one attribute.

                                                                                                                                                                                                                                                                            func (*PubsubMessage) MarshalJSON

                                                                                                                                                                                                                                                                            func (s *PubsubMessage) MarshalJSON() ([]byte, error)

                                                                                                                                                                                                                                                                            type PullRequest

                                                                                                                                                                                                                                                                            type PullRequest struct {
                                                                                                                                                                                                                                                                            	// MaxMessages: The maximum number of messages returned for this
                                                                                                                                                                                                                                                                            	// request. The Pub/Sub
                                                                                                                                                                                                                                                                            	// system may return fewer than the number specified.
                                                                                                                                                                                                                                                                            	MaxMessages int64 `json:"maxMessages,omitempty"`
                                                                                                                                                                                                                                                                            
                                                                                                                                                                                                                                                                            	// ReturnImmediately: If this is specified as true the system will
                                                                                                                                                                                                                                                                            	// respond immediately even if
                                                                                                                                                                                                                                                                            	// it is not able to return a message in the `Pull` response. Otherwise
                                                                                                                                                                                                                                                                            	// the
                                                                                                                                                                                                                                                                            	// system is allowed to wait until at least one message is available
                                                                                                                                                                                                                                                                            	// rather
                                                                                                                                                                                                                                                                            	// than returning no messages. The client may cancel the request if it
                                                                                                                                                                                                                                                                            	// does
                                                                                                                                                                                                                                                                            	// not wish to wait any longer for the response.
                                                                                                                                                                                                                                                                            	ReturnImmediately bool `json:"returnImmediately,omitempty"`
                                                                                                                                                                                                                                                                            
                                                                                                                                                                                                                                                                            	// ForceSendFields is a list of field names (e.g. "MaxMessages") to
                                                                                                                                                                                                                                                                            	// unconditionally include in API requests. By default, fields with
                                                                                                                                                                                                                                                                            	// empty values are omitted from API requests. However, any non-pointer,
                                                                                                                                                                                                                                                                            	// non-interface field appearing in ForceSendFields will be sent to the
                                                                                                                                                                                                                                                                            	// server regardless of whether the field is empty or not. This may be
                                                                                                                                                                                                                                                                            	// used to include empty fields in Patch requests.
                                                                                                                                                                                                                                                                            	ForceSendFields []string `json:"-"`
                                                                                                                                                                                                                                                                            
                                                                                                                                                                                                                                                                            	// NullFields is a list of field names (e.g. "MaxMessages") to include
                                                                                                                                                                                                                                                                            	// in API requests with the JSON null value. By default, fields with
                                                                                                                                                                                                                                                                            	// empty values are omitted from API requests. However, any field with
                                                                                                                                                                                                                                                                            	// an empty value appearing in NullFields will be sent to the server as
                                                                                                                                                                                                                                                                            	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                                                                                                                                                                            	// This may be used to include null fields in Patch requests.
                                                                                                                                                                                                                                                                            	NullFields []string `json:"-"`
                                                                                                                                                                                                                                                                            }

                                                                                                                                                                                                                                                                              PullRequest: Request for the `Pull` method.

                                                                                                                                                                                                                                                                              func (*PullRequest) MarshalJSON

                                                                                                                                                                                                                                                                              func (s *PullRequest) MarshalJSON() ([]byte, error)

                                                                                                                                                                                                                                                                              type PullResponse

                                                                                                                                                                                                                                                                              type PullResponse struct {
                                                                                                                                                                                                                                                                              	// ReceivedMessages: Received Pub/Sub messages. The Pub/Sub system will
                                                                                                                                                                                                                                                                              	// return zero messages if
                                                                                                                                                                                                                                                                              	// there are no more available in the backlog. The Pub/Sub system may
                                                                                                                                                                                                                                                                              	// return
                                                                                                                                                                                                                                                                              	// fewer than the `maxMessages` requested even if there are more
                                                                                                                                                                                                                                                                              	// messages
                                                                                                                                                                                                                                                                              	// available in the backlog.
                                                                                                                                                                                                                                                                              	ReceivedMessages []*ReceivedMessage `json:"receivedMessages,omitempty"`
                                                                                                                                                                                                                                                                              
                                                                                                                                                                                                                                                                              	// ServerResponse contains the HTTP response code and headers from the
                                                                                                                                                                                                                                                                              	// server.
                                                                                                                                                                                                                                                                              	googleapi.ServerResponse `json:"-"`
                                                                                                                                                                                                                                                                              
                                                                                                                                                                                                                                                                              	// ForceSendFields is a list of field names (e.g. "ReceivedMessages") to
                                                                                                                                                                                                                                                                              	// unconditionally include in API requests. By default, fields with
                                                                                                                                                                                                                                                                              	// empty values are omitted from API requests. However, any non-pointer,
                                                                                                                                                                                                                                                                              	// non-interface field appearing in ForceSendFields will be sent to the
                                                                                                                                                                                                                                                                              	// server regardless of whether the field is empty or not. This may be
                                                                                                                                                                                                                                                                              	// used to include empty fields in Patch requests.
                                                                                                                                                                                                                                                                              	ForceSendFields []string `json:"-"`
                                                                                                                                                                                                                                                                              
                                                                                                                                                                                                                                                                              	// NullFields is a list of field names (e.g. "ReceivedMessages") to
                                                                                                                                                                                                                                                                              	// include in API requests with the JSON null value. By default, fields
                                                                                                                                                                                                                                                                              	// with empty values are omitted from API requests. However, any field
                                                                                                                                                                                                                                                                              	// with an empty value appearing in NullFields will be sent to the
                                                                                                                                                                                                                                                                              	// server as null. It is an error if a field in this list has a
                                                                                                                                                                                                                                                                              	// non-empty value. This may be used to include null fields in Patch
                                                                                                                                                                                                                                                                              	// requests.
                                                                                                                                                                                                                                                                              	NullFields []string `json:"-"`
                                                                                                                                                                                                                                                                              }

                                                                                                                                                                                                                                                                                PullResponse: Response for the `Pull` method.

                                                                                                                                                                                                                                                                                func (*PullResponse) MarshalJSON

                                                                                                                                                                                                                                                                                func (s *PullResponse) MarshalJSON() ([]byte, error)

                                                                                                                                                                                                                                                                                type PushConfig

                                                                                                                                                                                                                                                                                type PushConfig struct {
                                                                                                                                                                                                                                                                                	// Attributes: Endpoint configuration attributes.
                                                                                                                                                                                                                                                                                	//
                                                                                                                                                                                                                                                                                	// Every endpoint has a set of API supported attributes that can be used
                                                                                                                                                                                                                                                                                	// to
                                                                                                                                                                                                                                                                                	// control different aspects of the message delivery.
                                                                                                                                                                                                                                                                                	//
                                                                                                                                                                                                                                                                                	// The currently supported attribute is `x-goog-version`, which you
                                                                                                                                                                                                                                                                                	// can
                                                                                                                                                                                                                                                                                	// use to change the format of the push message. This
                                                                                                                                                                                                                                                                                	// attribute
                                                                                                                                                                                                                                                                                	// indicates the version of the data expected by the endpoint.
                                                                                                                                                                                                                                                                                	// This
                                                                                                                                                                                                                                                                                	// controls the shape of the envelope (i.e. its fields and
                                                                                                                                                                                                                                                                                	// metadata).
                                                                                                                                                                                                                                                                                	// The endpoint version is based on the version of the Pub/Sub
                                                                                                                                                                                                                                                                                	// API.
                                                                                                                                                                                                                                                                                	//
                                                                                                                                                                                                                                                                                	// If not present during the `CreateSubscription` call, it will default
                                                                                                                                                                                                                                                                                	// to
                                                                                                                                                                                                                                                                                	// the version of the API used to make such call. If not present during
                                                                                                                                                                                                                                                                                	// a
                                                                                                                                                                                                                                                                                	// `ModifyPushConfig` call, its value will not be changed.
                                                                                                                                                                                                                                                                                	// `GetSubscription`
                                                                                                                                                                                                                                                                                	// calls will always return a valid version, even if the subscription
                                                                                                                                                                                                                                                                                	// was
                                                                                                                                                                                                                                                                                	// created without this attribute.
                                                                                                                                                                                                                                                                                	//
                                                                                                                                                                                                                                                                                	// The possible values for this attribute are:
                                                                                                                                                                                                                                                                                	//
                                                                                                                                                                                                                                                                                	// * `v1beta1`: uses the push format defined in the v1beta1 Pub/Sub
                                                                                                                                                                                                                                                                                	// API.
                                                                                                                                                                                                                                                                                	// * `v1` or `v1beta2`: uses the push format defined in the v1 Pub/Sub
                                                                                                                                                                                                                                                                                	// API.
                                                                                                                                                                                                                                                                                	Attributes map[string]string `json:"attributes,omitempty"`
                                                                                                                                                                                                                                                                                
                                                                                                                                                                                                                                                                                	// OidcToken: If specified, Pub/Sub will generate and attach an OIDC JWT
                                                                                                                                                                                                                                                                                	// token as an
                                                                                                                                                                                                                                                                                	// `Authorization` header in the HTTP request for every pushed message.
                                                                                                                                                                                                                                                                                	OidcToken *OidcToken `json:"oidcToken,omitempty"`
                                                                                                                                                                                                                                                                                
                                                                                                                                                                                                                                                                                	// PushEndpoint: A URL locating the endpoint to which messages should be
                                                                                                                                                                                                                                                                                	// pushed.
                                                                                                                                                                                                                                                                                	// For example, a Webhook endpoint might use "https://example.com/push".
                                                                                                                                                                                                                                                                                	PushEndpoint string `json:"pushEndpoint,omitempty"`
                                                                                                                                                                                                                                                                                
                                                                                                                                                                                                                                                                                	// ForceSendFields is a list of field names (e.g. "Attributes") to
                                                                                                                                                                                                                                                                                	// unconditionally include in API requests. By default, fields with
                                                                                                                                                                                                                                                                                	// empty values are omitted from API requests. However, any non-pointer,
                                                                                                                                                                                                                                                                                	// non-interface field appearing in ForceSendFields will be sent to the
                                                                                                                                                                                                                                                                                	// server regardless of whether the field is empty or not. This may be
                                                                                                                                                                                                                                                                                	// used to include empty fields in Patch requests.
                                                                                                                                                                                                                                                                                	ForceSendFields []string `json:"-"`
                                                                                                                                                                                                                                                                                
                                                                                                                                                                                                                                                                                	// NullFields is a list of field names (e.g. "Attributes") to include in
                                                                                                                                                                                                                                                                                	// API requests with the JSON null value. By default, fields with empty
                                                                                                                                                                                                                                                                                	// values are omitted from API requests. However, any field with an
                                                                                                                                                                                                                                                                                	// empty value appearing in NullFields will be sent to the server as
                                                                                                                                                                                                                                                                                	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                                                                                                                                                                                	// This may be used to include null fields in Patch requests.
                                                                                                                                                                                                                                                                                	NullFields []string `json:"-"`
                                                                                                                                                                                                                                                                                }

                                                                                                                                                                                                                                                                                  PushConfig: Configuration for a push delivery endpoint.

                                                                                                                                                                                                                                                                                  func (*PushConfig) MarshalJSON

                                                                                                                                                                                                                                                                                  func (s *PushConfig) MarshalJSON() ([]byte, error)

                                                                                                                                                                                                                                                                                  type ReceivedMessage

                                                                                                                                                                                                                                                                                  type ReceivedMessage struct {
                                                                                                                                                                                                                                                                                  	// AckId: This ID can be used to acknowledge the received message.
                                                                                                                                                                                                                                                                                  	AckId string `json:"ackId,omitempty"`
                                                                                                                                                                                                                                                                                  
                                                                                                                                                                                                                                                                                  	// Message: The message.
                                                                                                                                                                                                                                                                                  	Message *PubsubMessage `json:"message,omitempty"`
                                                                                                                                                                                                                                                                                  
                                                                                                                                                                                                                                                                                  	// ForceSendFields is a list of field names (e.g. "AckId") to
                                                                                                                                                                                                                                                                                  	// unconditionally include in API requests. By default, fields with
                                                                                                                                                                                                                                                                                  	// empty values are omitted from API requests. However, any non-pointer,
                                                                                                                                                                                                                                                                                  	// non-interface field appearing in ForceSendFields will be sent to the
                                                                                                                                                                                                                                                                                  	// server regardless of whether the field is empty or not. This may be
                                                                                                                                                                                                                                                                                  	// used to include empty fields in Patch requests.
                                                                                                                                                                                                                                                                                  	ForceSendFields []string `json:"-"`
                                                                                                                                                                                                                                                                                  
                                                                                                                                                                                                                                                                                  	// NullFields is a list of field names (e.g. "AckId") to include in API
                                                                                                                                                                                                                                                                                  	// requests with the JSON null value. By default, fields with empty
                                                                                                                                                                                                                                                                                  	// values are omitted from API requests. However, any field with an
                                                                                                                                                                                                                                                                                  	// empty value appearing in NullFields will be sent to the server as
                                                                                                                                                                                                                                                                                  	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                                                                                                                                                                                  	// This may be used to include null fields in Patch requests.
                                                                                                                                                                                                                                                                                  	NullFields []string `json:"-"`
                                                                                                                                                                                                                                                                                  }

                                                                                                                                                                                                                                                                                    ReceivedMessage: A message and its corresponding acknowledgment ID.

                                                                                                                                                                                                                                                                                    func (*ReceivedMessage) MarshalJSON

                                                                                                                                                                                                                                                                                    func (s *ReceivedMessage) MarshalJSON() ([]byte, error)

                                                                                                                                                                                                                                                                                    type Service

                                                                                                                                                                                                                                                                                    type Service struct {
                                                                                                                                                                                                                                                                                    	BasePath  string // API endpoint base URL
                                                                                                                                                                                                                                                                                    	UserAgent string // optional additional User-Agent fragment
                                                                                                                                                                                                                                                                                    
                                                                                                                                                                                                                                                                                    	Projects *ProjectsService
                                                                                                                                                                                                                                                                                    	// contains filtered or unexported fields
                                                                                                                                                                                                                                                                                    }

                                                                                                                                                                                                                                                                                    func New

                                                                                                                                                                                                                                                                                    func New(client *http.Client) (*Service, error)

                                                                                                                                                                                                                                                                                      New creates a new Service. It uses the provided http.Client for requests.

                                                                                                                                                                                                                                                                                      Deprecated: please use NewService instead. To provide a custom HTTP client, use option.WithHTTPClient. If you are using google.golang.org/api/googleapis/transport.APIKey, use option.WithAPIKey with NewService instead.

                                                                                                                                                                                                                                                                                      func NewService

                                                                                                                                                                                                                                                                                      func NewService(ctx context.Context, opts ...option.ClientOption) (*Service, error)

                                                                                                                                                                                                                                                                                        NewService creates a new Service.

                                                                                                                                                                                                                                                                                        type SetIamPolicyRequest

                                                                                                                                                                                                                                                                                        type SetIamPolicyRequest struct {
                                                                                                                                                                                                                                                                                        	// Policy: REQUIRED: The complete policy to be applied to the
                                                                                                                                                                                                                                                                                        	// `resource`. The size of
                                                                                                                                                                                                                                                                                        	// the policy is limited to a few 10s of KB. An empty policy is a
                                                                                                                                                                                                                                                                                        	// valid policy but certain Cloud Platform services (such as
                                                                                                                                                                                                                                                                                        	// Projects)
                                                                                                                                                                                                                                                                                        	// might reject them.
                                                                                                                                                                                                                                                                                        	Policy *Policy `json:"policy,omitempty"`
                                                                                                                                                                                                                                                                                        
                                                                                                                                                                                                                                                                                        	// ForceSendFields is a list of field names (e.g. "Policy") to
                                                                                                                                                                                                                                                                                        	// unconditionally include in API requests. By default, fields with
                                                                                                                                                                                                                                                                                        	// empty values are omitted from API requests. However, any non-pointer,
                                                                                                                                                                                                                                                                                        	// non-interface field appearing in ForceSendFields will be sent to the
                                                                                                                                                                                                                                                                                        	// server regardless of whether the field is empty or not. This may be
                                                                                                                                                                                                                                                                                        	// used to include empty fields in Patch requests.
                                                                                                                                                                                                                                                                                        	ForceSendFields []string `json:"-"`
                                                                                                                                                                                                                                                                                        
                                                                                                                                                                                                                                                                                        	// NullFields is a list of field names (e.g. "Policy") to include in API
                                                                                                                                                                                                                                                                                        	// requests with the JSON null value. By default, fields with empty
                                                                                                                                                                                                                                                                                        	// values are omitted from API requests. However, any field with an
                                                                                                                                                                                                                                                                                        	// empty value appearing in NullFields will be sent to the server as
                                                                                                                                                                                                                                                                                        	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                                                                                                                                                                                        	// This may be used to include null fields in Patch requests.
                                                                                                                                                                                                                                                                                        	NullFields []string `json:"-"`
                                                                                                                                                                                                                                                                                        }

                                                                                                                                                                                                                                                                                          SetIamPolicyRequest: Request message for `SetIamPolicy` method.

                                                                                                                                                                                                                                                                                          func (*SetIamPolicyRequest) MarshalJSON

                                                                                                                                                                                                                                                                                          func (s *SetIamPolicyRequest) MarshalJSON() ([]byte, error)

                                                                                                                                                                                                                                                                                          type Subscription

                                                                                                                                                                                                                                                                                          type Subscription struct {
                                                                                                                                                                                                                                                                                          	// AckDeadlineSeconds: This value is the maximum time after a subscriber
                                                                                                                                                                                                                                                                                          	// receives a message
                                                                                                                                                                                                                                                                                          	// before the subscriber should acknowledge the message. After
                                                                                                                                                                                                                                                                                          	// message
                                                                                                                                                                                                                                                                                          	// delivery but before the ack deadline expires and before the message
                                                                                                                                                                                                                                                                                          	// is
                                                                                                                                                                                                                                                                                          	// acknowledged, it is an outstanding message and will not be
                                                                                                                                                                                                                                                                                          	// delivered
                                                                                                                                                                                                                                                                                          	// again during that time (on a best-effort basis).
                                                                                                                                                                                                                                                                                          	//
                                                                                                                                                                                                                                                                                          	// For pull subscriptions, this value is used as the initial value for
                                                                                                                                                                                                                                                                                          	// the ack
                                                                                                                                                                                                                                                                                          	// deadline. To override this value for a given message,
                                                                                                                                                                                                                                                                                          	// call
                                                                                                                                                                                                                                                                                          	// `ModifyAckDeadline` with the corresponding `ack_id` if using
                                                                                                                                                                                                                                                                                          	// pull.
                                                                                                                                                                                                                                                                                          	// The maximum custom deadline you can specify is 600 seconds (10
                                                                                                                                                                                                                                                                                          	// minutes).
                                                                                                                                                                                                                                                                                          	//
                                                                                                                                                                                                                                                                                          	// For push delivery, this value is also used to set the request timeout
                                                                                                                                                                                                                                                                                          	// for
                                                                                                                                                                                                                                                                                          	// the call to the push endpoint.
                                                                                                                                                                                                                                                                                          	//
                                                                                                                                                                                                                                                                                          	// If the subscriber never acknowledges the message, the Pub/Sub
                                                                                                                                                                                                                                                                                          	// system will eventually redeliver the message.
                                                                                                                                                                                                                                                                                          	//
                                                                                                                                                                                                                                                                                          	// If this parameter is 0, a default value of 10 seconds is used.
                                                                                                                                                                                                                                                                                          	AckDeadlineSeconds int64 `json:"ackDeadlineSeconds,omitempty"`
                                                                                                                                                                                                                                                                                          
                                                                                                                                                                                                                                                                                          	// Name: The name of the subscription. It must have the
                                                                                                                                                                                                                                                                                          	// format
                                                                                                                                                                                                                                                                                          	// "projects/{project}/subscriptions/{subscription}". `{subscription}`
                                                                                                                                                                                                                                                                                          	// must
                                                                                                                                                                                                                                                                                          	// start with a letter, and contain only letters (`[A-Za-z]`),
                                                                                                                                                                                                                                                                                          	// numbers
                                                                                                                                                                                                                                                                                          	// (`[0-9]`), dashes (`-`), underscores (`_`), periods (`.`), tildes
                                                                                                                                                                                                                                                                                          	// (`~`),
                                                                                                                                                                                                                                                                                          	// plus (`+`) or percent signs (`%`). It must be between 3 and 255
                                                                                                                                                                                                                                                                                          	// characters
                                                                                                                                                                                                                                                                                          	// in length, and it must not start with "goog".
                                                                                                                                                                                                                                                                                          	Name string `json:"name,omitempty"`
                                                                                                                                                                                                                                                                                          
                                                                                                                                                                                                                                                                                          	// PushConfig: If push delivery is used with this subscription, this
                                                                                                                                                                                                                                                                                          	// field is
                                                                                                                                                                                                                                                                                          	// used to configure it. An empty `pushConfig` signifies that the
                                                                                                                                                                                                                                                                                          	// subscriber
                                                                                                                                                                                                                                                                                          	// will pull and ack messages using API methods.
                                                                                                                                                                                                                                                                                          	PushConfig *PushConfig `json:"pushConfig,omitempty"`
                                                                                                                                                                                                                                                                                          
                                                                                                                                                                                                                                                                                          	// Topic: The name of the topic from which this subscription is
                                                                                                                                                                                                                                                                                          	// receiving messages.
                                                                                                                                                                                                                                                                                          	// The value of this field will be `_deleted-topic_` if the topic has
                                                                                                                                                                                                                                                                                          	// been
                                                                                                                                                                                                                                                                                          	// deleted.
                                                                                                                                                                                                                                                                                          	Topic string `json:"topic,omitempty"`
                                                                                                                                                                                                                                                                                          
                                                                                                                                                                                                                                                                                          	// ServerResponse contains the HTTP response code and headers from the
                                                                                                                                                                                                                                                                                          	// server.
                                                                                                                                                                                                                                                                                          	googleapi.ServerResponse `json:"-"`
                                                                                                                                                                                                                                                                                          
                                                                                                                                                                                                                                                                                          	// ForceSendFields is a list of field names (e.g. "AckDeadlineSeconds")
                                                                                                                                                                                                                                                                                          	// to unconditionally include in API requests. By default, fields with
                                                                                                                                                                                                                                                                                          	// empty values are omitted from API requests. However, any non-pointer,
                                                                                                                                                                                                                                                                                          	// non-interface field appearing in ForceSendFields will be sent to the
                                                                                                                                                                                                                                                                                          	// server regardless of whether the field is empty or not. This may be
                                                                                                                                                                                                                                                                                          	// used to include empty fields in Patch requests.
                                                                                                                                                                                                                                                                                          	ForceSendFields []string `json:"-"`
                                                                                                                                                                                                                                                                                          
                                                                                                                                                                                                                                                                                          	// NullFields is a list of field names (e.g. "AckDeadlineSeconds") to
                                                                                                                                                                                                                                                                                          	// include in API requests with the JSON null value. By default, fields
                                                                                                                                                                                                                                                                                          	// with empty values are omitted from API requests. However, any field
                                                                                                                                                                                                                                                                                          	// with an empty value appearing in NullFields will be sent to the
                                                                                                                                                                                                                                                                                          	// server as null. It is an error if a field in this list has a
                                                                                                                                                                                                                                                                                          	// non-empty value. This may be used to include null fields in Patch
                                                                                                                                                                                                                                                                                          	// requests.
                                                                                                                                                                                                                                                                                          	NullFields []string `json:"-"`
                                                                                                                                                                                                                                                                                          }

                                                                                                                                                                                                                                                                                            Subscription: A subscription resource.

                                                                                                                                                                                                                                                                                            func (*Subscription) MarshalJSON

                                                                                                                                                                                                                                                                                            func (s *Subscription) MarshalJSON() ([]byte, error)

                                                                                                                                                                                                                                                                                            type TestIamPermissionsRequest

                                                                                                                                                                                                                                                                                            type TestIamPermissionsRequest struct {
                                                                                                                                                                                                                                                                                            	// Permissions: The set of permissions to check for the `resource`.
                                                                                                                                                                                                                                                                                            	// Permissions with
                                                                                                                                                                                                                                                                                            	// wildcards (such as '*' or 'storage.*') are not allowed. For
                                                                                                                                                                                                                                                                                            	// more
                                                                                                                                                                                                                                                                                            	// information see
                                                                                                                                                                                                                                                                                            	// [IAM
                                                                                                                                                                                                                                                                                            	// Overview](https://cloud.google.com/iam/docs/overview#permissions).
                                                                                                                                                                                                                                                                                            	Permissions []string `json:"permissions,omitempty"`
                                                                                                                                                                                                                                                                                            
                                                                                                                                                                                                                                                                                            	// ForceSendFields is a list of field names (e.g. "Permissions") to
                                                                                                                                                                                                                                                                                            	// unconditionally include in API requests. By default, fields with
                                                                                                                                                                                                                                                                                            	// empty values are omitted from API requests. However, any non-pointer,
                                                                                                                                                                                                                                                                                            	// non-interface field appearing in ForceSendFields will be sent to the
                                                                                                                                                                                                                                                                                            	// server regardless of whether the field is empty or not. This may be
                                                                                                                                                                                                                                                                                            	// used to include empty fields in Patch requests.
                                                                                                                                                                                                                                                                                            	ForceSendFields []string `json:"-"`
                                                                                                                                                                                                                                                                                            
                                                                                                                                                                                                                                                                                            	// NullFields is a list of field names (e.g. "Permissions") to include
                                                                                                                                                                                                                                                                                            	// in API requests with the JSON null value. By default, fields with
                                                                                                                                                                                                                                                                                            	// empty values are omitted from API requests. However, any field with
                                                                                                                                                                                                                                                                                            	// an empty value appearing in NullFields will be sent to the server as
                                                                                                                                                                                                                                                                                            	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                                                                                                                                                                                            	// This may be used to include null fields in Patch requests.
                                                                                                                                                                                                                                                                                            	NullFields []string `json:"-"`
                                                                                                                                                                                                                                                                                            }

                                                                                                                                                                                                                                                                                              TestIamPermissionsRequest: Request message for `TestIamPermissions` method.

                                                                                                                                                                                                                                                                                              func (*TestIamPermissionsRequest) MarshalJSON

                                                                                                                                                                                                                                                                                              func (s *TestIamPermissionsRequest) MarshalJSON() ([]byte, error)

                                                                                                                                                                                                                                                                                              type TestIamPermissionsResponse

                                                                                                                                                                                                                                                                                              type TestIamPermissionsResponse struct {
                                                                                                                                                                                                                                                                                              	// Permissions: A subset of `TestPermissionsRequest.permissions` that
                                                                                                                                                                                                                                                                                              	// the caller is
                                                                                                                                                                                                                                                                                              	// allowed.
                                                                                                                                                                                                                                                                                              	Permissions []string `json:"permissions,omitempty"`
                                                                                                                                                                                                                                                                                              
                                                                                                                                                                                                                                                                                              	// ServerResponse contains the HTTP response code and headers from the
                                                                                                                                                                                                                                                                                              	// server.
                                                                                                                                                                                                                                                                                              	googleapi.ServerResponse `json:"-"`
                                                                                                                                                                                                                                                                                              
                                                                                                                                                                                                                                                                                              	// ForceSendFields is a list of field names (e.g. "Permissions") to
                                                                                                                                                                                                                                                                                              	// unconditionally include in API requests. By default, fields with
                                                                                                                                                                                                                                                                                              	// empty values are omitted from API requests. However, any non-pointer,
                                                                                                                                                                                                                                                                                              	// non-interface field appearing in ForceSendFields will be sent to the
                                                                                                                                                                                                                                                                                              	// server regardless of whether the field is empty or not. This may be
                                                                                                                                                                                                                                                                                              	// used to include empty fields in Patch requests.
                                                                                                                                                                                                                                                                                              	ForceSendFields []string `json:"-"`
                                                                                                                                                                                                                                                                                              
                                                                                                                                                                                                                                                                                              	// NullFields is a list of field names (e.g. "Permissions") to include
                                                                                                                                                                                                                                                                                              	// in API requests with the JSON null value. By default, fields with
                                                                                                                                                                                                                                                                                              	// empty values are omitted from API requests. However, any field with
                                                                                                                                                                                                                                                                                              	// an empty value appearing in NullFields will be sent to the server as
                                                                                                                                                                                                                                                                                              	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                                                                                                                                                                                              	// This may be used to include null fields in Patch requests.
                                                                                                                                                                                                                                                                                              	NullFields []string `json:"-"`
                                                                                                                                                                                                                                                                                              }

                                                                                                                                                                                                                                                                                                TestIamPermissionsResponse: Response message for `TestIamPermissions` method.

                                                                                                                                                                                                                                                                                                func (*TestIamPermissionsResponse) MarshalJSON

                                                                                                                                                                                                                                                                                                func (s *TestIamPermissionsResponse) MarshalJSON() ([]byte, error)

                                                                                                                                                                                                                                                                                                type Topic

                                                                                                                                                                                                                                                                                                type Topic struct {
                                                                                                                                                                                                                                                                                                	// Name: The name of the topic. It must have the
                                                                                                                                                                                                                                                                                                	// format
                                                                                                                                                                                                                                                                                                	// "projects/{project}/topics/{topic}". `{topic}` must start with a
                                                                                                                                                                                                                                                                                                	// letter,
                                                                                                                                                                                                                                                                                                	// and contain only letters (`[A-Za-z]`), numbers (`[0-9]`), dashes
                                                                                                                                                                                                                                                                                                	// (`-`),
                                                                                                                                                                                                                                                                                                	// underscores (`_`), periods (`.`), tildes (`~`), plus (`+`) or
                                                                                                                                                                                                                                                                                                	// percent
                                                                                                                                                                                                                                                                                                	// signs (`%`). It must be between 3 and 255 characters in length, and
                                                                                                                                                                                                                                                                                                	// it
                                                                                                                                                                                                                                                                                                	// must not start with "goog".
                                                                                                                                                                                                                                                                                                	Name string `json:"name,omitempty"`
                                                                                                                                                                                                                                                                                                
                                                                                                                                                                                                                                                                                                	// ServerResponse contains the HTTP response code and headers from the
                                                                                                                                                                                                                                                                                                	// server.
                                                                                                                                                                                                                                                                                                	googleapi.ServerResponse `json:"-"`
                                                                                                                                                                                                                                                                                                
                                                                                                                                                                                                                                                                                                	// ForceSendFields is a list of field names (e.g. "Name") to
                                                                                                                                                                                                                                                                                                	// unconditionally include in API requests. By default, fields with
                                                                                                                                                                                                                                                                                                	// empty values are omitted from API requests. However, any non-pointer,
                                                                                                                                                                                                                                                                                                	// non-interface field appearing in ForceSendFields will be sent to the
                                                                                                                                                                                                                                                                                                	// server regardless of whether the field is empty or not. This may be
                                                                                                                                                                                                                                                                                                	// used to include empty fields in Patch requests.
                                                                                                                                                                                                                                                                                                	ForceSendFields []string `json:"-"`
                                                                                                                                                                                                                                                                                                
                                                                                                                                                                                                                                                                                                	// NullFields is a list of field names (e.g. "Name") to include in API
                                                                                                                                                                                                                                                                                                	// requests with the JSON null value. By default, fields with empty
                                                                                                                                                                                                                                                                                                	// values are omitted from API requests. However, any field with an
                                                                                                                                                                                                                                                                                                	// empty value appearing in NullFields will be sent to the server as
                                                                                                                                                                                                                                                                                                	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                                                                                                                                                                                                	// This may be used to include null fields in Patch requests.
                                                                                                                                                                                                                                                                                                	NullFields []string `json:"-"`
                                                                                                                                                                                                                                                                                                }

                                                                                                                                                                                                                                                                                                  Topic: A topic resource.

                                                                                                                                                                                                                                                                                                  func (*Topic) MarshalJSON

                                                                                                                                                                                                                                                                                                  func (s *Topic) MarshalJSON() ([]byte, error)

                                                                                                                                                                                                                                                                                                  Source Files