// Copyright 2024 Google LLC. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. // Code generated file. DO NOT EDIT. // Package osconfig provides access to the OS Config API. // // For product documentation, see: https://cloud.google.com/compute/docs/osconfig/rest // // # Library status // // These client libraries are officially supported by Google. However, this // library is considered complete and is in maintenance mode. This means // that we will address critical bugs and security issues but will not add // any new features. // // When possible, we recommend using our newer // [Cloud Client Libraries for Go](https://pkg.go.dev/cloud.google.com/go) // that are still actively being worked and iterated on. // // # Creating a client // // Usage example: // // import "google.golang.org/api/osconfig/v1beta" // ... // ctx := context.Background() // osconfigService, err := osconfig.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 // // To use an API key for authentication (note: some APIs do not support API // keys), use [google.golang.org/api/option.WithAPIKey]: // // osconfigService, err := osconfig.NewService(ctx, option.WithAPIKey("AIza...")) // // To use an OAuth token (e.g., a user token obtained via a three-legged OAuth // flow, use [google.golang.org/api/option.WithTokenSource]: // // config := &oauth2.Config{...} // // ... // token, err := config.Exchange(ctx, ...) // osconfigService, err := osconfig.NewService(ctx, option.WithTokenSource(config.TokenSource(ctx, token))) // // See [google.golang.org/api/option.ClientOption] for details on options. package osconfig // import "google.golang.org/api/osconfig/v1beta" import ( "bytes" "context" "encoding/json" "errors" "fmt" "io" "net/http" "net/url" "strconv" "strings" googleapi "google.golang.org/api/googleapi" internal "google.golang.org/api/internal" gensupport "google.golang.org/api/internal/gensupport" option "google.golang.org/api/option" internaloption "google.golang.org/api/option/internaloption" htransport "google.golang.org/api/transport/http" ) // Always reference these packages, just in case the auto-generated code // below doesn't. var _ = bytes.NewBuffer var _ = strconv.Itoa var _ = fmt.Sprintf var _ = json.NewDecoder var _ = io.Copy var _ = url.Parse var _ = gensupport.MarshalJSON var _ = googleapi.Version var _ = errors.New var _ = strings.Replace var _ = context.Canceled var _ = internaloption.WithDefaultEndpoint var _ = internal.Version const apiId = "osconfig:v1beta" const apiName = "osconfig" const apiVersion = "v1beta" const basePath = "https://osconfig.googleapis.com/" const basePathTemplate = "https://osconfig.UNIVERSE_DOMAIN/" const mtlsBasePath = "https://osconfig.mtls.googleapis.com/" // OAuth2 scopes used by this API. const ( // See, edit, configure, and delete your Google Cloud data and see the email // address for your Google Account. CloudPlatformScope = "https://www.googleapis.com/auth/cloud-platform" ) // NewService creates a new Service. func NewService(ctx context.Context, opts ...option.ClientOption) (*Service, error) { scopesOption := internaloption.WithDefaultScopes( "https://www.googleapis.com/auth/cloud-platform", ) // NOTE: prepend, so we don't override user-specified scopes. opts = append([]option.ClientOption{scopesOption}, opts...) opts = append(opts, internaloption.WithDefaultEndpoint(basePath)) opts = append(opts, internaloption.WithDefaultEndpointTemplate(basePathTemplate)) opts = append(opts, internaloption.WithDefaultMTLSEndpoint(mtlsBasePath)) opts = append(opts, internaloption.EnableNewAuthLibrary()) client, endpoint, err := htransport.NewClient(ctx, opts...) if err != nil { return nil, err } s, err := New(client) if err != nil { return nil, err } if endpoint != "" { s.BasePath = endpoint } return s, nil } // 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 New(client *http.Client) (*Service, error) { if client == nil { return nil, errors.New("client is nil") } s := &Service{client: client, BasePath: basePath} s.Projects = NewProjectsService(s) return s, nil } type Service struct { client *http.Client BasePath string // API endpoint base URL UserAgent string // optional additional User-Agent fragment Projects *ProjectsService } func (s *Service) userAgent() string { if s.UserAgent == "" { return googleapi.UserAgent } return googleapi.UserAgent + " " + s.UserAgent } func NewProjectsService(s *Service) *ProjectsService { rs := &ProjectsService{s: s} rs.GuestPolicies = NewProjectsGuestPoliciesService(s) rs.PatchDeployments = NewProjectsPatchDeploymentsService(s) rs.PatchJobs = NewProjectsPatchJobsService(s) rs.Zones = NewProjectsZonesService(s) return rs } type ProjectsService struct { s *Service GuestPolicies *ProjectsGuestPoliciesService PatchDeployments *ProjectsPatchDeploymentsService PatchJobs *ProjectsPatchJobsService Zones *ProjectsZonesService } func NewProjectsGuestPoliciesService(s *Service) *ProjectsGuestPoliciesService { rs := &ProjectsGuestPoliciesService{s: s} return rs } type ProjectsGuestPoliciesService struct { s *Service } func NewProjectsPatchDeploymentsService(s *Service) *ProjectsPatchDeploymentsService { rs := &ProjectsPatchDeploymentsService{s: s} return rs } type ProjectsPatchDeploymentsService struct { s *Service } func NewProjectsPatchJobsService(s *Service) *ProjectsPatchJobsService { rs := &ProjectsPatchJobsService{s: s} rs.InstanceDetails = NewProjectsPatchJobsInstanceDetailsService(s) return rs } type ProjectsPatchJobsService struct { s *Service InstanceDetails *ProjectsPatchJobsInstanceDetailsService } func NewProjectsPatchJobsInstanceDetailsService(s *Service) *ProjectsPatchJobsInstanceDetailsService { rs := &ProjectsPatchJobsInstanceDetailsService{s: s} return rs } type ProjectsPatchJobsInstanceDetailsService struct { s *Service } func NewProjectsZonesService(s *Service) *ProjectsZonesService { rs := &ProjectsZonesService{s: s} rs.Instances = NewProjectsZonesInstancesService(s) return rs } type ProjectsZonesService struct { s *Service Instances *ProjectsZonesInstancesService } func NewProjectsZonesInstancesService(s *Service) *ProjectsZonesInstancesService { rs := &ProjectsZonesInstancesService{s: s} return rs } type ProjectsZonesInstancesService struct { s *Service } // AptRepository: Represents a single Apt package repository. This repository // is added to a repo file that is stored at // `/etc/apt/sources.list.d/google_osconfig.list`. type AptRepository struct { // ArchiveType: Type of archive files in this repository. The default behavior // is DEB. // // Possible values: // "ARCHIVE_TYPE_UNSPECIFIED" - Unspecified. // "DEB" - DEB indicates that the archive contains binary files. // "DEB_SRC" - DEB_SRC indicates that the archive contains source files. ArchiveType string `json:"archiveType,omitempty"` // Components: Required. List of components for this repository. Must contain // at least one item. Components []string `json:"components,omitempty"` // Distribution: Required. Distribution of this repository. Distribution string `json:"distribution,omitempty"` // GpgKey: URI of the key file for this repository. The agent maintains a // keyring at `/etc/apt/trusted.gpg.d/osconfig_agent_managed.gpg` containing // all the keys in any applied guest policy. GpgKey string `json:"gpgKey,omitempty"` // Uri: Required. URI for this repository. Uri string `json:"uri,omitempty"` // ForceSendFields is a list of field names (e.g. "ArchiveType") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "ArchiveType") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *AptRepository) MarshalJSON() ([]byte, error) { type NoMethod AptRepository return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // AptSettings: Apt patching is completed by executing `apt-get update && // apt-get upgrade`. Additional options can be set to control how this is // executed. type AptSettings struct { // Excludes: List of packages to exclude from update. These packages will be // excluded Excludes []string `json:"excludes,omitempty"` // ExclusivePackages: An exclusive list of packages to be updated. These are // the only packages that will be updated. If these packages are not installed, // they will be ignored. This field cannot be specified with any other patch // configuration fields. ExclusivePackages []string `json:"exclusivePackages,omitempty"` // Type: By changing the type to DIST, the patching is performed using `apt-get // dist-upgrade` instead. // // Possible values: // "TYPE_UNSPECIFIED" - By default, upgrade will be performed. // "DIST" - Runs `apt-get dist-upgrade`. // "UPGRADE" - Runs `apt-get upgrade`. Type string `json:"type,omitempty"` // ForceSendFields is a list of field names (e.g. "Excludes") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Excludes") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *AptSettings) MarshalJSON() ([]byte, error) { type NoMethod AptSettings return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // Assignment: An assignment represents the group or groups of VM instances // that the policy applies to. If an assignment is empty, it applies to all VM // instances. Otherwise, the targeted VM instances must meet all the criteria // specified. So if both labels and zones are specified, the policy applies to // VM instances with those labels and in those zones. type Assignment struct { // GroupLabels: Targets instances matching at least one of these label sets. // This allows an assignment to target disparate groups, for example "env=prod // or env=staging". GroupLabels []*AssignmentGroupLabel `json:"groupLabels,omitempty"` // InstanceNamePrefixes: Targets VM instances whose name starts with one of // these prefixes. Like labels, this is another way to group VM instances when // targeting configs, for example prefix="prod-". Only supported for // project-level policies. InstanceNamePrefixes []string `json:"instanceNamePrefixes,omitempty"` // Instances: Targets any of the instances specified. Instances are specified // by their URI in the form `zones/[ZONE]/instances/[INSTANCE_NAME]`. Instance // targeting is uncommon and is supported to facilitate the management of // changes by the instance or to target specific VM instances for development // and testing. Only supported for project-level policies and must reference // instances within this project. Instances []string `json:"instances,omitempty"` // OsTypes: Targets VM instances matching at least one of the following OS // types. VM instances must match all supplied criteria for a given OsType to // be included. OsTypes []*AssignmentOsType `json:"osTypes,omitempty"` // Zones: Targets instances in any of these zones. Leave empty to target // instances in any zone. Zonal targeting is uncommon and is supported to // facilitate the management of changes by zone. Zones []string `json:"zones,omitempty"` // ForceSendFields is a list of field names (e.g. "GroupLabels") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "GroupLabels") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *Assignment) MarshalJSON() ([]byte, error) { type NoMethod Assignment return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // AssignmentGroupLabel: Represents a group of VM intances that can be // identified as having all these labels, for example "env=prod and app=web". type AssignmentGroupLabel struct { // Labels: Google Compute Engine instance labels that must be present for an // instance to be included in this assignment group. Labels map[string]string `json:"labels,omitempty"` // ForceSendFields is a list of field names (e.g. "Labels") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Labels") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *AssignmentGroupLabel) MarshalJSON() ([]byte, error) { type NoMethod AssignmentGroupLabel return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // AssignmentOsType: Defines the criteria for selecting VM Instances by OS // type. type AssignmentOsType struct { // OsArchitecture: Targets VM instances with OS Inventory enabled and having // the following OS architecture. OsArchitecture string `json:"osArchitecture,omitempty"` // OsShortName: Targets VM instances with OS Inventory enabled and having the // following OS short name, for example "debian" or "windows". OsShortName string `json:"osShortName,omitempty"` // OsVersion: Targets VM instances with OS Inventory enabled and having the // following following OS version. OsVersion string `json:"osVersion,omitempty"` // ForceSendFields is a list of field names (e.g. "OsArchitecture") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "OsArchitecture") to include in // API requests with the JSON null value. By default, fields with empty values // are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *AssignmentOsType) MarshalJSON() ([]byte, error) { type NoMethod AssignmentOsType return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // CancelPatchJobRequest: Message for canceling a patch job. type CancelPatchJobRequest struct { } // EffectiveGuestPolicy: The effective guest policy that applies to a VM // instance. type EffectiveGuestPolicy struct { // PackageRepositories: List of package repository configurations assigned to // the VM instance. PackageRepositories []*EffectiveGuestPolicySourcedPackageRepository `json:"packageRepositories,omitempty"` // Packages: List of package configurations assigned to the VM instance. Packages []*EffectiveGuestPolicySourcedPackage `json:"packages,omitempty"` // SoftwareRecipes: List of recipes assigned to the VM instance. SoftwareRecipes []*EffectiveGuestPolicySourcedSoftwareRecipe `json:"softwareRecipes,omitempty"` // ServerResponse contains the HTTP response code and headers from the server. googleapi.ServerResponse `json:"-"` // ForceSendFields is a list of field names (e.g. "PackageRepositories") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "PackageRepositories") to include // in API requests with the JSON null value. By default, fields with empty // values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *EffectiveGuestPolicy) MarshalJSON() ([]byte, error) { type NoMethod EffectiveGuestPolicy return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // EffectiveGuestPolicySourcedPackage: A guest policy package including its // source. type EffectiveGuestPolicySourcedPackage struct { // Package: A software package to configure on the VM instance. Package *Package `json:"package,omitempty"` // Source: Name of the guest policy providing this config. Source string `json:"source,omitempty"` // ForceSendFields is a list of field names (e.g. "Package") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Package") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *EffectiveGuestPolicySourcedPackage) MarshalJSON() ([]byte, error) { type NoMethod EffectiveGuestPolicySourcedPackage return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // EffectiveGuestPolicySourcedPackageRepository: A guest policy package // repository including its source. type EffectiveGuestPolicySourcedPackageRepository struct { // PackageRepository: A software package repository to configure on the VM // instance. PackageRepository *PackageRepository `json:"packageRepository,omitempty"` // Source: Name of the guest policy providing this config. Source string `json:"source,omitempty"` // ForceSendFields is a list of field names (e.g. "PackageRepository") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "PackageRepository") to include in // API requests with the JSON null value. By default, fields with empty values // are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *EffectiveGuestPolicySourcedPackageRepository) MarshalJSON() ([]byte, error) { type NoMethod EffectiveGuestPolicySourcedPackageRepository return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // EffectiveGuestPolicySourcedSoftwareRecipe: A guest policy recipe including // its source. type EffectiveGuestPolicySourcedSoftwareRecipe struct { // SoftwareRecipe: A software recipe to configure on the VM instance. SoftwareRecipe *SoftwareRecipe `json:"softwareRecipe,omitempty"` // Source: Name of the guest policy providing this config. Source string `json:"source,omitempty"` // ForceSendFields is a list of field names (e.g. "SoftwareRecipe") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "SoftwareRecipe") to include in // API requests with the JSON null value. By default, fields with empty values // are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *EffectiveGuestPolicySourcedSoftwareRecipe) MarshalJSON() ([]byte, error) { type NoMethod EffectiveGuestPolicySourcedSoftwareRecipe return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // 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); } type Empty struct { // ServerResponse contains the HTTP response code and headers from the server. googleapi.ServerResponse `json:"-"` } // ExecStep: A step that runs an executable for a PatchJob. type ExecStep struct { // LinuxExecStepConfig: The ExecStepConfig for all Linux VMs targeted by the // PatchJob. LinuxExecStepConfig *ExecStepConfig `json:"linuxExecStepConfig,omitempty"` // WindowsExecStepConfig: The ExecStepConfig for all Windows VMs targeted by // the PatchJob. WindowsExecStepConfig *ExecStepConfig `json:"windowsExecStepConfig,omitempty"` // ForceSendFields is a list of field names (e.g. "LinuxExecStepConfig") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "LinuxExecStepConfig") to include // in API requests with the JSON null value. By default, fields with empty // values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *ExecStep) MarshalJSON() ([]byte, error) { type NoMethod ExecStep return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // ExecStepConfig: Common configurations for an ExecStep. type ExecStepConfig struct { // AllowedSuccessCodes: Defaults to [0]. A list of possible return values that // the execution can return to indicate a success. AllowedSuccessCodes []int64 `json:"allowedSuccessCodes,omitempty"` // GcsObject: A Google Cloud Storage object containing the executable. GcsObject *GcsObject `json:"gcsObject,omitempty"` // Interpreter: The script interpreter to use to run the script. If no // interpreter is specified the script will be executed directly, which will // likely only succeed for scripts with [shebang lines] // (https://en.wikipedia.org/wiki/Shebang_\(Unix\)). // // Possible values: // "INTERPRETER_UNSPECIFIED" - If the interpreter is not specified, the value // defaults to `NONE`. // "NONE" - Indicates that the file is run as follows on each operating // system: + For Linux VMs, the file is ran as an executable and the // interpreter might be parsed from the [shebang // line](https://wikipedia.org/wiki/Shebang_(Unix)) of the file. + For Windows // VM, this value is not supported. // "SHELL" - Indicates that the file is run with `/bin/sh` on Linux and `cmd` // on Windows. // "POWERSHELL" - Indicates that the file is run with PowerShell. Interpreter string `json:"interpreter,omitempty"` // LocalPath: An absolute path to the executable on the VM. LocalPath string `json:"localPath,omitempty"` // ForceSendFields is a list of field names (e.g. "AllowedSuccessCodes") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "AllowedSuccessCodes") to include // in API requests with the JSON null value. By default, fields with empty // values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *ExecStepConfig) MarshalJSON() ([]byte, error) { type NoMethod ExecStepConfig return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // ExecutePatchJobRequest: A request message to initiate patching across // Compute Engine instances. type ExecutePatchJobRequest struct { // Description: Description of the patch job. Length of the description is // limited to 1024 characters. Description string `json:"description,omitempty"` // DisplayName: Display name for this patch job. This does not have to be // unique. DisplayName string `json:"displayName,omitempty"` // DryRun: If this patch is a dry-run only, instances are contacted but will do // nothing. DryRun bool `json:"dryRun,omitempty"` // Duration: Duration of the patch job. After the duration ends, the patch job // times out. Duration string `json:"duration,omitempty"` // InstanceFilter: Required. Instances to patch, either explicitly or filtered // by some criteria such as zone or labels. InstanceFilter *PatchInstanceFilter `json:"instanceFilter,omitempty"` // PatchConfig: Patch configuration being applied. If omitted, instances are // patched using the default configurations. PatchConfig *PatchConfig `json:"patchConfig,omitempty"` // Rollout: Rollout strategy of the patch job. Rollout *PatchRollout `json:"rollout,omitempty"` // ForceSendFields is a list of field names (e.g. "Description") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. 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. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *ExecutePatchJobRequest) MarshalJSON() ([]byte, error) { type NoMethod ExecutePatchJobRequest return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // FixedOrPercent: Message encapsulating a value that can be either absolute // ("fixed") or relative ("percent") to a value. type FixedOrPercent struct { // Fixed: Specifies a fixed value. Fixed int64 `json:"fixed,omitempty"` // Percent: Specifies the relative value defined as a percentage, which will be // multiplied by a reference value. Percent int64 `json:"percent,omitempty"` // ForceSendFields is a list of field names (e.g. "Fixed") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Fixed") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *FixedOrPercent) MarshalJSON() ([]byte, error) { type NoMethod FixedOrPercent return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // GcsObject: Google Cloud Storage object representation. type GcsObject struct { // Bucket: Required. Bucket of the Google Cloud Storage object. Bucket string `json:"bucket,omitempty"` // GenerationNumber: Required. Generation number of the Google Cloud Storage // object. This is used to ensure that the ExecStep specified by this PatchJob // does not change. GenerationNumber int64 `json:"generationNumber,omitempty,string"` // Object: Required. Name of the Google Cloud Storage object. Object string `json:"object,omitempty"` // ForceSendFields is a list of field names (e.g. "Bucket") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Bucket") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *GcsObject) MarshalJSON() ([]byte, error) { type NoMethod GcsObject return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // GooRepository: Represents a Goo package repository. These is added to a repo // file that is stored at C:/ProgramData/GooGet/repos/google_osconfig.repo. type GooRepository struct { // Name: Required. The name of the repository. Name string `json:"name,omitempty"` // Url: Required. The url of the repository. Url string `json:"url,omitempty"` // ForceSendFields is a list of field names (e.g. "Name") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. 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. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *GooRepository) MarshalJSON() ([]byte, error) { type NoMethod GooRepository return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // GooSettings: Googet patching is performed by running `googet update`. type GooSettings struct { } // GoogleCloudOsconfigV1__OSPolicyAssignmentOperationMetadata: OS policy // assignment operation metadata provided by OS policy assignment API methods // that return long running operations. type GoogleCloudOsconfigV1__OSPolicyAssignmentOperationMetadata struct { // ApiMethod: The OS policy assignment API method. // // Possible values: // "API_METHOD_UNSPECIFIED" - Invalid value // "CREATE" - Create OS policy assignment API method // "UPDATE" - Update OS policy assignment API method // "DELETE" - Delete OS policy assignment API method ApiMethod string `json:"apiMethod,omitempty"` // OsPolicyAssignment: Reference to the `OSPolicyAssignment` API resource. // Format: // `projects/{project_number}/locations/{location}/osPolicyAssignments/{os_polic // y_assignment_id@revision_id}` OsPolicyAssignment string `json:"osPolicyAssignment,omitempty"` // RolloutStartTime: Rollout start time RolloutStartTime string `json:"rolloutStartTime,omitempty"` // RolloutState: State of the rollout // // Possible values: // "ROLLOUT_STATE_UNSPECIFIED" - Invalid value // "IN_PROGRESS" - The rollout is in progress. // "CANCELLING" - The rollout is being cancelled. // "CANCELLED" - The rollout is cancelled. // "SUCCEEDED" - The rollout has completed successfully. RolloutState string `json:"rolloutState,omitempty"` // RolloutUpdateTime: Rollout update time RolloutUpdateTime string `json:"rolloutUpdateTime,omitempty"` // ForceSendFields is a list of field names (e.g. "ApiMethod") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "ApiMethod") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *GoogleCloudOsconfigV1__OSPolicyAssignmentOperationMetadata) MarshalJSON() ([]byte, error) { type NoMethod GoogleCloudOsconfigV1__OSPolicyAssignmentOperationMetadata return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // GuestPolicy: An OS Config resource representing a guest configuration // policy. These policies represent the desired state for VM instance guest // environments including packages to install or remove, package repository // configurations, and software to install. type GuestPolicy struct { // Assignment: Required. Specifies the VM instances that are assigned to this // policy. This allows you to target sets or groups of VM instances by // different parameters such as labels, names, OS, or zones. If left empty, all // VM instances underneath this policy are targeted. At the same level in the // resource hierarchy (that is within a project), the service prevents the // creation of multiple policies that conflict with each other. For more // information, see how the service handles assignment conflicts // (/compute/docs/os-config-management/create-guest-policy#handle-conflicts). Assignment *Assignment `json:"assignment,omitempty"` // CreateTime: Output only. Time this guest policy was created. CreateTime string `json:"createTime,omitempty"` // Description: Description of the guest policy. Length of the description is // limited to 1024 characters. Description string `json:"description,omitempty"` // Etag: The etag for this guest policy. If this is provided on update, it must // match the server's etag. Etag string `json:"etag,omitempty"` // Name: Required. Unique name of the resource in this project using one of the // following forms: // `projects/{project_number}/guestPolicies/{guest_policy_id}`. Name string `json:"name,omitempty"` // PackageRepositories: A list of package repositories to configure on the VM // instance. This is done before any other configs are applied so they can use // these repos. Package repositories are only configured if the corresponding // package manager(s) are available. PackageRepositories []*PackageRepository `json:"packageRepositories,omitempty"` // Packages: The software packages to be managed by this policy. Packages []*Package `json:"packages,omitempty"` // Recipes: A list of Recipes to install on the VM instance. Recipes []*SoftwareRecipe `json:"recipes,omitempty"` // UpdateTime: Output only. Last time this guest policy was updated. UpdateTime string `json:"updateTime,omitempty"` // ServerResponse contains the HTTP response code and headers from the server. googleapi.ServerResponse `json:"-"` // ForceSendFields is a list of field names (e.g. "Assignment") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Assignment") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *GuestPolicy) MarshalJSON() ([]byte, error) { type NoMethod GuestPolicy return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // ListGuestPoliciesResponse: A response message for listing guest policies. type ListGuestPoliciesResponse struct { // GuestPolicies: The list of GuestPolicies. GuestPolicies []*GuestPolicy `json:"guestPolicies,omitempty"` // NextPageToken: A pagination token that can be used to get the next page of // guest policies. NextPageToken string `json:"nextPageToken,omitempty"` // ServerResponse contains the HTTP response code and headers from the server. googleapi.ServerResponse `json:"-"` // ForceSendFields is a list of field names (e.g. "GuestPolicies") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "GuestPolicies") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *ListGuestPoliciesResponse) MarshalJSON() ([]byte, error) { type NoMethod ListGuestPoliciesResponse return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // ListPatchDeploymentsResponse: A response message for listing patch // deployments. type ListPatchDeploymentsResponse struct { // NextPageToken: A pagination token that can be used to get the next page of // patch deployments. NextPageToken string `json:"nextPageToken,omitempty"` // PatchDeployments: The list of patch deployments. PatchDeployments []*PatchDeployment `json:"patchDeployments,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 or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. 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. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *ListPatchDeploymentsResponse) MarshalJSON() ([]byte, error) { type NoMethod ListPatchDeploymentsResponse return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // ListPatchJobInstanceDetailsResponse: A response message for listing the // instances details for a patch job. type ListPatchJobInstanceDetailsResponse struct { // NextPageToken: A pagination token that can be used to get the next page of // results. NextPageToken string `json:"nextPageToken,omitempty"` // PatchJobInstanceDetails: A list of instance status. PatchJobInstanceDetails []*PatchJobInstanceDetails `json:"patchJobInstanceDetails,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 or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. 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. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *ListPatchJobInstanceDetailsResponse) MarshalJSON() ([]byte, error) { type NoMethod ListPatchJobInstanceDetailsResponse return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // ListPatchJobsResponse: A response message for listing patch jobs. type ListPatchJobsResponse struct { // NextPageToken: A pagination token that can be used to get the next page of // results. NextPageToken string `json:"nextPageToken,omitempty"` // PatchJobs: The list of patch jobs. PatchJobs []*PatchJob `json:"patchJobs,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 or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. 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. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *ListPatchJobsResponse) MarshalJSON() ([]byte, error) { type NoMethod ListPatchJobsResponse return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // LookupEffectiveGuestPolicyRequest: A request message for getting the // effective guest policy assigned to the instance. type LookupEffectiveGuestPolicyRequest struct { // OsArchitecture: Architecture of OS running on the instance. The OS Config // agent only provides this field for targeting if OS Inventory is enabled for // that instance. OsArchitecture string `json:"osArchitecture,omitempty"` // OsShortName: Short name of the OS running on the instance. The OS Config // agent only provides this field for targeting if OS Inventory is enabled for // that instance. OsShortName string `json:"osShortName,omitempty"` // OsVersion: Version of the OS running on the instance. The OS Config agent // only provides this field for targeting if OS Inventory is enabled for that // VM instance. OsVersion string `json:"osVersion,omitempty"` // ForceSendFields is a list of field names (e.g. "OsArchitecture") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "OsArchitecture") to include in // API requests with the JSON null value. By default, fields with empty values // are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *LookupEffectiveGuestPolicyRequest) MarshalJSON() ([]byte, error) { type NoMethod LookupEffectiveGuestPolicyRequest return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // MonthlySchedule: Represents a monthly schedule. An example of a valid // monthly schedule is "on the third Tuesday of the month" or "on the 15th of // the month". type MonthlySchedule struct { // MonthDay: Required. One day of the month. 1-31 indicates the 1st to the 31st // day. -1 indicates the last day of the month. Months without the target day // will be skipped. For example, a schedule to run "every month on the 31st" // will not run in February, April, June, etc. MonthDay int64 `json:"monthDay,omitempty"` // WeekDayOfMonth: Required. Week day in a month. WeekDayOfMonth *WeekDayOfMonth `json:"weekDayOfMonth,omitempty"` // ForceSendFields is a list of field names (e.g. "MonthDay") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "MonthDay") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *MonthlySchedule) MarshalJSON() ([]byte, error) { type NoMethod MonthlySchedule return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // OSPolicyAssignmentOperationMetadata: OS policy assignment operation metadata // provided by OS policy assignment API methods that return long running // operations. type OSPolicyAssignmentOperationMetadata struct { // ApiMethod: The OS policy assignment API method. // // Possible values: // "API_METHOD_UNSPECIFIED" - Invalid value // "CREATE" - Create OS policy assignment API method // "UPDATE" - Update OS policy assignment API method // "DELETE" - Delete OS policy assignment API method ApiMethod string `json:"apiMethod,omitempty"` // OsPolicyAssignment: Reference to the `OSPolicyAssignment` API resource. // Format: // `projects/{project_number}/locations/{location}/osPolicyAssignments/{os_polic // y_assignment_id@revision_id}` OsPolicyAssignment string `json:"osPolicyAssignment,omitempty"` // RolloutStartTime: Rollout start time RolloutStartTime string `json:"rolloutStartTime,omitempty"` // RolloutState: State of the rollout // // Possible values: // "ROLLOUT_STATE_UNSPECIFIED" - Invalid value // "IN_PROGRESS" - The rollout is in progress. // "CANCELLING" - The rollout is being cancelled. // "CANCELLED" - The rollout is cancelled. // "SUCCEEDED" - The rollout has completed successfully. RolloutState string `json:"rolloutState,omitempty"` // RolloutUpdateTime: Rollout update time RolloutUpdateTime string `json:"rolloutUpdateTime,omitempty"` // ForceSendFields is a list of field names (e.g. "ApiMethod") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "ApiMethod") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *OSPolicyAssignmentOperationMetadata) MarshalJSON() ([]byte, error) { type NoMethod OSPolicyAssignmentOperationMetadata return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // OneTimeSchedule: Sets the time for a one time patch deployment. Timestamp is // in RFC3339 (https://www.ietf.org/rfc/rfc3339.txt) text format. type OneTimeSchedule struct { // ExecuteTime: Required. The desired patch job execution time. ExecuteTime string `json:"executeTime,omitempty"` // ForceSendFields is a list of field names (e.g. "ExecuteTime") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "ExecuteTime") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *OneTimeSchedule) MarshalJSON() ([]byte, error) { type NoMethod OneTimeSchedule return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // Package: Package is a reference to the software package to be installed or // removed. The agent on the VM instance uses the system package manager to // apply the config. These are the commands that the agent uses to install or // remove packages. Apt install: `apt-get update && apt-get -y install package1 // package2 package3` remove: `apt-get -y remove package1 package2 package3` // Yum install: `yum -y install package1 package2 package3` remove: `yum -y // remove package1 package2 package3` Zypper install: `zypper install package1 // package2 package3` remove: `zypper rm package1 package2` Googet install: // `googet -noconfirm install package1 package2 package3` remove: `googet // -noconfirm remove package1 package2 package3` type Package struct { // DesiredState: The desired_state the agent should maintain for this package. // The default is to ensure the package is installed. // // Possible values: // "DESIRED_STATE_UNSPECIFIED" - The default is to ensure the package is // installed. // "INSTALLED" - The agent ensures that the package is installed. // "UPDATED" - The agent ensures that the package is installed and // periodically checks for and install any updates. // "REMOVED" - The agent ensures that the package is not installed and // uninstall it if detected. DesiredState string `json:"desiredState,omitempty"` // Manager: Type of package manager that can be used to install this package. // If a system does not have the package manager, the package is not installed // or removed no error message is returned. By default, or if you specify // `ANY`, the agent attempts to install and remove this package using the // default package manager. This is useful when creating a policy that applies // to different types of systems. The default behavior is ANY. // // Possible values: // "MANAGER_UNSPECIFIED" - The default behavior is ANY. // "ANY" - Apply this package config using the default system package // manager. // "APT" - Apply this package config only if Apt is available on the system. // "YUM" - Apply this package config only if Yum is available on the system. // "ZYPPER" - Apply this package config only if Zypper is available on the // system. // "GOO" - Apply this package config only if GooGet is available on the // system. Manager string `json:"manager,omitempty"` // Name: Required. The name of the package. A package is uniquely identified // for conflict validation by checking the package name and the manager(s) that // the package targets. Name string `json:"name,omitempty"` // ForceSendFields is a list of field names (e.g. "DesiredState") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "DesiredState") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *Package) MarshalJSON() ([]byte, error) { type NoMethod Package return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // PackageRepository: A package repository. type PackageRepository struct { // Apt: An Apt Repository. Apt *AptRepository `json:"apt,omitempty"` // Goo: A Goo Repository. Goo *GooRepository `json:"goo,omitempty"` // Yum: A Yum Repository. Yum *YumRepository `json:"yum,omitempty"` // Zypper: A Zypper Repository. Zypper *ZypperRepository `json:"zypper,omitempty"` // ForceSendFields is a list of field names (e.g. "Apt") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Apt") to include in API requests // with the JSON null value. By default, fields with empty values are omitted // from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *PackageRepository) MarshalJSON() ([]byte, error) { type NoMethod PackageRepository return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // PatchConfig: Patch configuration specifications. Contains details on how to // apply the patch(es) to a VM instance. type PatchConfig struct { // Apt: Apt update settings. Use this setting to override the default `apt` // patch rules. Apt *AptSettings `json:"apt,omitempty"` // Goo: Goo update settings. Use this setting to override the default `goo` // patch rules. Goo *GooSettings `json:"goo,omitempty"` // MigInstancesAllowed: Allows the patch job to run on Managed instance groups // (MIGs). MigInstancesAllowed bool `json:"migInstancesAllowed,omitempty"` // PostStep: The `ExecStep` to run after the patch update. PostStep *ExecStep `json:"postStep,omitempty"` // PreStep: The `ExecStep` to run before the patch update. PreStep *ExecStep `json:"preStep,omitempty"` // RebootConfig: Post-patch reboot settings. // // Possible values: // "REBOOT_CONFIG_UNSPECIFIED" - The default behavior is DEFAULT. // "DEFAULT" - The agent decides if a reboot is necessary by checking signals // such as registry keys on Windows or `/var/run/reboot-required` on APT based // systems. On RPM based systems, a set of core system package install times // are compared with system boot time. // "ALWAYS" - Always reboot the machine after the update completes. // "NEVER" - Never reboot the machine after the update completes. RebootConfig string `json:"rebootConfig,omitempty"` // WindowsUpdate: Windows update settings. Use this override the default // windows patch rules. WindowsUpdate *WindowsUpdateSettings `json:"windowsUpdate,omitempty"` // Yum: Yum update settings. Use this setting to override the default `yum` // patch rules. Yum *YumSettings `json:"yum,omitempty"` // Zypper: Zypper update settings. Use this setting to override the default // `zypper` patch rules. Zypper *ZypperSettings `json:"zypper,omitempty"` // ForceSendFields is a list of field names (e.g. "Apt") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Apt") to include in API requests // with the JSON null value. By default, fields with empty values are omitted // from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *PatchConfig) MarshalJSON() ([]byte, error) { type NoMethod PatchConfig return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // PatchDeployment: Patch deployments are configurations that individual patch // jobs use to complete a patch. These configurations include instance filter, // package repository settings, and a schedule. For more information about // creating and managing patch deployments, see Scheduling patch jobs // (https://cloud.google.com/compute/docs/os-patch-management/schedule-patch-jobs). type PatchDeployment struct { // CreateTime: Output only. Time the patch deployment was created. Timestamp is // in RFC3339 (https://www.ietf.org/rfc/rfc3339.txt) text format. CreateTime string `json:"createTime,omitempty"` // Description: Optional. Description of the patch deployment. Length of the // description is limited to 1024 characters. Description string `json:"description,omitempty"` // Duration: Optional. Duration of the patch. After the duration ends, the // patch times out. Duration string `json:"duration,omitempty"` // InstanceFilter: Required. VM instances to patch. InstanceFilter *PatchInstanceFilter `json:"instanceFilter,omitempty"` // LastExecuteTime: Output only. The last time a patch job was started by this // deployment. Timestamp is in RFC3339 (https://www.ietf.org/rfc/rfc3339.txt) // text format. LastExecuteTime string `json:"lastExecuteTime,omitempty"` // Name: Unique name for the patch deployment resource in a project. The patch // deployment name is in the form: // `projects/{project_id}/patchDeployments/{patch_deployment_id}`. This field // is ignored when you create a new patch deployment. Name string `json:"name,omitempty"` // OneTimeSchedule: Required. Schedule a one-time execution. OneTimeSchedule *OneTimeSchedule `json:"oneTimeSchedule,omitempty"` // PatchConfig: Optional. Patch configuration that is applied. PatchConfig *PatchConfig `json:"patchConfig,omitempty"` // RecurringSchedule: Required. Schedule recurring executions. RecurringSchedule *RecurringSchedule `json:"recurringSchedule,omitempty"` // Rollout: Optional. Rollout strategy of the patch job. Rollout *PatchRollout `json:"rollout,omitempty"` // State: Output only. Current state of the patch deployment. // // Possible values: // "STATE_UNSPECIFIED" - The default value. This value is used if the state // is omitted. // "ACTIVE" - Active value means that patch deployment generates Patch Jobs. // "PAUSED" - Paused value means that patch deployment does not generate // Patch jobs. Requires user action to move in and out from this state. State string `json:"state,omitempty"` // UpdateTime: Output only. Time the patch deployment was last updated. // Timestamp is in RFC3339 (https://www.ietf.org/rfc/rfc3339.txt) text format. UpdateTime string `json:"updateTime,omitempty"` // ServerResponse contains the HTTP response code and headers from the server. googleapi.ServerResponse `json:"-"` // ForceSendFields is a list of field names (e.g. "CreateTime") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "CreateTime") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *PatchDeployment) MarshalJSON() ([]byte, error) { type NoMethod PatchDeployment return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // PatchInstanceFilter: A filter to target VM instances for patching. The // targeted VMs must meet all criteria specified. So if both labels and zones // are specified, the patch job targets only VMs with those labels and in those // zones. type PatchInstanceFilter struct { // All: Target all VM instances in the project. If true, no other criteria is // permitted. All bool `json:"all,omitempty"` // GroupLabels: Targets VM instances matching at least one of these label sets. // This allows targeting of disparate groups, for example "env=prod or // env=staging". GroupLabels []*PatchInstanceFilterGroupLabel `json:"groupLabels,omitempty"` // InstanceNamePrefixes: Targets VMs whose name starts with one of these // prefixes. Similar to labels, this is another way to group VMs when targeting // configs, for example prefix="prod-". InstanceNamePrefixes []string `json:"instanceNamePrefixes,omitempty"` // Instances: Targets any of the VM instances specified. Instances are // specified by their URI in the form `zones/[ZONE]/instances/[INSTANCE_NAME]`, // `projects/[PROJECT_ID]/zones/[ZONE]/instances/[INSTANCE_NAME]`, or // `https://www.googleapis.com/compute/v1/projects/[PROJECT_ID]/zones/[ZONE]/ins // tances/[INSTANCE_NAME]` Instances []string `json:"instances,omitempty"` // Zones: Targets VM instances in ANY of these zones. Leave empty to target VM // instances in any zone. Zones []string `json:"zones,omitempty"` // ForceSendFields is a list of field names (e.g. "All") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "All") to include in API requests // with the JSON null value. By default, fields with empty values are omitted // from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *PatchInstanceFilter) MarshalJSON() ([]byte, error) { type NoMethod PatchInstanceFilter return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // PatchInstanceFilterGroupLabel: Represents a group of VMs that can be // identified as having all these labels, for example "env=prod and app=web". type PatchInstanceFilterGroupLabel struct { // Labels: Compute Engine instance labels that must be present for a VM // instance to be targeted by this filter. Labels map[string]string `json:"labels,omitempty"` // ForceSendFields is a list of field names (e.g. "Labels") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Labels") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *PatchInstanceFilterGroupLabel) MarshalJSON() ([]byte, error) { type NoMethod PatchInstanceFilterGroupLabel return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // PatchJob: A high level representation of a patch job that is either in // progress or has completed. Instance details are not included in the job. To // paginate through instance details, use `ListPatchJobInstanceDetails`. For // more information about patch jobs, see Creating patch jobs // (https://cloud.google.com/compute/docs/os-patch-management/create-patch-job). type PatchJob struct { // CreateTime: Time this patch job was created. CreateTime string `json:"createTime,omitempty"` // Description: Description of the patch job. Length of the description is // limited to 1024 characters. Description string `json:"description,omitempty"` // DisplayName: Display name for this patch job. This is not a unique // identifier. DisplayName string `json:"displayName,omitempty"` // DryRun: If this patch job is a dry run, the agent reports that it has // finished without running any updates on the VM instance. DryRun bool `json:"dryRun,omitempty"` // Duration: Duration of the patch job. After the duration ends, the patch job // times out. Duration string `json:"duration,omitempty"` // ErrorMessage: If this patch job failed, this message provides information // about the failure. ErrorMessage string `json:"errorMessage,omitempty"` // InstanceDetailsSummary: Summary of instance details. InstanceDetailsSummary *PatchJobInstanceDetailsSummary `json:"instanceDetailsSummary,omitempty"` // InstanceFilter: Instances to patch. InstanceFilter *PatchInstanceFilter `json:"instanceFilter,omitempty"` // Name: Unique identifier for this patch job in the form // `projects/*/patchJobs/*` Name string `json:"name,omitempty"` // PatchConfig: Patch configuration being applied. PatchConfig *PatchConfig `json:"patchConfig,omitempty"` // PatchDeployment: Output only. Name of the patch deployment that created this // patch job. PatchDeployment string `json:"patchDeployment,omitempty"` // PercentComplete: Reflects the overall progress of the patch job in the range // of 0.0 being no progress to 100.0 being complete. PercentComplete float64 `json:"percentComplete,omitempty"` // Rollout: Rollout strategy being applied. Rollout *PatchRollout `json:"rollout,omitempty"` // State: The current state of the PatchJob. // // Possible values: // "STATE_UNSPECIFIED" - State must be specified. // "STARTED" - The patch job was successfully initiated. // "INSTANCE_LOOKUP" - The patch job is looking up instances to run the patch // on. // "PATCHING" - Instances are being patched. // "SUCCEEDED" - Patch job completed successfully. // "COMPLETED_WITH_ERRORS" - Patch job completed but there were errors. // "CANCELED" - The patch job was canceled. // "TIMED_OUT" - The patch job timed out. State string `json:"state,omitempty"` // UpdateTime: Last time this patch job was updated. UpdateTime string `json:"updateTime,omitempty"` // ServerResponse contains the HTTP response code and headers from the server. googleapi.ServerResponse `json:"-"` // ForceSendFields is a list of field names (e.g. "CreateTime") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "CreateTime") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *PatchJob) MarshalJSON() ([]byte, error) { type NoMethod PatchJob return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } func (s *PatchJob) UnmarshalJSON(data []byte) error { type NoMethod PatchJob var s1 struct { PercentComplete gensupport.JSONFloat64 `json:"percentComplete"` *NoMethod } s1.NoMethod = (*NoMethod)(s) if err := json.Unmarshal(data, &s1); err != nil { return err } s.PercentComplete = float64(s1.PercentComplete) return nil } // PatchJobInstanceDetails: Patch details for a VM instance. For more // information about reviewing VM instance details, see Listing all VM instance // details for a specific patch job // (https://cloud.google.com/compute/docs/os-patch-management/manage-patch-jobs#list-instance-details). type PatchJobInstanceDetails struct { // AttemptCount: The number of times the agent that the agent attempts to apply // the patch. AttemptCount int64 `json:"attemptCount,omitempty,string"` // FailureReason: If the patch fails, this field provides the reason. FailureReason string `json:"failureReason,omitempty"` // InstanceSystemId: The unique identifier for the instance. This identifier is // defined by the server. InstanceSystemId string `json:"instanceSystemId,omitempty"` // Name: The instance name in the form `projects/*/zones/*/instances/*` Name string `json:"name,omitempty"` // State: Current state of instance patch. // // Possible values: // "PATCH_STATE_UNSPECIFIED" - Unspecified. // "PENDING" - The instance is not yet notified. // "INACTIVE" - Instance is inactive and cannot be patched. // "NOTIFIED" - The instance is notified that it should be patched. // "STARTED" - The instance has started the patching process. // "DOWNLOADING_PATCHES" - The instance is downloading patches. // "APPLYING_PATCHES" - The instance is applying patches. // "REBOOTING" - The instance is rebooting. // "SUCCEEDED" - The instance has completed applying patches. // "SUCCEEDED_REBOOT_REQUIRED" - The instance has completed applying patches // but a reboot is required. // "FAILED" - The instance has failed to apply the patch. // "ACKED" - The instance acked the notification and will start shortly. // "TIMED_OUT" - The instance exceeded the time out while applying the patch. // "RUNNING_PRE_PATCH_STEP" - The instance is running the pre-patch step. // "RUNNING_POST_PATCH_STEP" - The instance is running the post-patch step. // "NO_AGENT_DETECTED" - The service could not detect the presence of the // agent. Check to ensure that the agent is installed, running, and able to // communicate with the service. State string `json:"state,omitempty"` // ForceSendFields is a list of field names (e.g. "AttemptCount") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "AttemptCount") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *PatchJobInstanceDetails) MarshalJSON() ([]byte, error) { type NoMethod PatchJobInstanceDetails return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // PatchJobInstanceDetailsSummary: A summary of the current patch state across // all instances that this patch job affects. Contains counts of instances in // different states. These states map to `InstancePatchState`. List patch job // instance details to see the specific states of each instance. type PatchJobInstanceDetailsSummary struct { // AckedInstanceCount: Number of instances that have acked and will start // shortly. AckedInstanceCount int64 `json:"ackedInstanceCount,omitempty,string"` // ApplyingPatchesInstanceCount: Number of instances that are applying patches. ApplyingPatchesInstanceCount int64 `json:"applyingPatchesInstanceCount,omitempty,string"` // DownloadingPatchesInstanceCount: Number of instances that are downloading // patches. DownloadingPatchesInstanceCount int64 `json:"downloadingPatchesInstanceCount,omitempty,string"` // FailedInstanceCount: Number of instances that failed. FailedInstanceCount int64 `json:"failedInstanceCount,omitempty,string"` // InactiveInstanceCount: Number of instances that are inactive. InactiveInstanceCount int64 `json:"inactiveInstanceCount,omitempty,string"` // NoAgentDetectedInstanceCount: Number of instances that do not appear to be // running the agent. Check to ensure that the agent is installed, running, and // able to communicate with the service. NoAgentDetectedInstanceCount int64 `json:"noAgentDetectedInstanceCount,omitempty,string"` // NotifiedInstanceCount: Number of instances notified about patch job. NotifiedInstanceCount int64 `json:"notifiedInstanceCount,omitempty,string"` // PendingInstanceCount: Number of instances pending patch job. PendingInstanceCount int64 `json:"pendingInstanceCount,omitempty,string"` // PostPatchStepInstanceCount: Number of instances that are running the // post-patch step. PostPatchStepInstanceCount int64 `json:"postPatchStepInstanceCount,omitempty,string"` // PrePatchStepInstanceCount: Number of instances that are running the // pre-patch step. PrePatchStepInstanceCount int64 `json:"prePatchStepInstanceCount,omitempty,string"` // RebootingInstanceCount: Number of instances rebooting. RebootingInstanceCount int64 `json:"rebootingInstanceCount,omitempty,string"` // StartedInstanceCount: Number of instances that have started. StartedInstanceCount int64 `json:"startedInstanceCount,omitempty,string"` // SucceededInstanceCount: Number of instances that have completed // successfully. SucceededInstanceCount int64 `json:"succeededInstanceCount,omitempty,string"` // SucceededRebootRequiredInstanceCount: Number of instances that require // reboot. SucceededRebootRequiredInstanceCount int64 `json:"succeededRebootRequiredInstanceCount,omitempty,string"` // TimedOutInstanceCount: Number of instances that exceeded the time out while // applying the patch. TimedOutInstanceCount int64 `json:"timedOutInstanceCount,omitempty,string"` // ForceSendFields is a list of field names (e.g. "AckedInstanceCount") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "AckedInstanceCount") to include // in API requests with the JSON null value. By default, fields with empty // values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *PatchJobInstanceDetailsSummary) MarshalJSON() ([]byte, error) { type NoMethod PatchJobInstanceDetailsSummary return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // PatchRollout: Patch rollout configuration specifications. Contains details // on the concurrency control when applying patch(es) to all targeted VMs. type PatchRollout struct { // DisruptionBudget: The maximum number (or percentage) of VMs per zone to // disrupt at any given moment. The number of VMs calculated from multiplying // the percentage by the total number of VMs in a zone is rounded up. During // patching, a VM is considered disrupted from the time the agent is notified // to begin until patching has completed. This disruption time includes the // time to complete reboot and any post-patch steps. A VM contributes to the // disruption budget if its patching operation fails either when applying the // patches, running pre or post patch steps, or if it fails to respond with a // success notification before timing out. VMs that are not running or do not // have an active agent do not count toward this disruption budget. For // zone-by-zone rollouts, if the disruption budget in a zone is exceeded, the // patch job stops, because continuing to the next zone requires completion of // the patch process in the previous zone. For example, if the disruption // budget has a fixed value of `10`, and 8 VMs fail to patch in the current // zone, the patch job continues to patch 2 VMs at a time until the zone is // completed. When that zone is completed successfully, patching begins with 10 // VMs at a time in the next zone. If 10 VMs in the next zone fail to patch, // the patch job stops. DisruptionBudget *FixedOrPercent `json:"disruptionBudget,omitempty"` // Mode: Mode of the patch rollout. // // Possible values: // "MODE_UNSPECIFIED" - Mode must be specified. // "ZONE_BY_ZONE" - Patches are applied one zone at a time. The patch job // begins in the region with the lowest number of targeted VMs. Within the // region, patching begins in the zone with the lowest number of targeted VMs. // If multiple regions (or zones within a region) have the same number of // targeted VMs, a tie-breaker is achieved by sorting the regions or zones in // alphabetical order. // "CONCURRENT_ZONES" - Patches are applied to VMs in all zones at the same // time. Mode string `json:"mode,omitempty"` // ForceSendFields is a list of field names (e.g. "DisruptionBudget") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "DisruptionBudget") to include in // API requests with the JSON null value. By default, fields with empty values // are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *PatchRollout) MarshalJSON() ([]byte, error) { type NoMethod PatchRollout return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // PausePatchDeploymentRequest: A request message for pausing a patch // deployment. type PausePatchDeploymentRequest struct { } // RecurringSchedule: Sets the time for recurring patch deployments. type RecurringSchedule struct { // EndTime: Optional. The end time at which a recurring patch deployment // schedule is no longer active. EndTime string `json:"endTime,omitempty"` // Frequency: Required. The frequency unit of this recurring schedule. // // Possible values: // "FREQUENCY_UNSPECIFIED" - Invalid. A frequency must be specified. // "WEEKLY" - Indicates that the frequency of recurrence should be expressed // in terms of weeks. // "MONTHLY" - Indicates that the frequency of recurrence should be expressed // in terms of months. // "DAILY" - Indicates that the frequency of recurrence should be expressed // in terms of days. Frequency string `json:"frequency,omitempty"` // LastExecuteTime: Output only. The time the last patch job ran successfully. LastExecuteTime string `json:"lastExecuteTime,omitempty"` // Monthly: Required. Schedule with monthly executions. Monthly *MonthlySchedule `json:"monthly,omitempty"` // NextExecuteTime: Output only. The time the next patch job is scheduled to // run. NextExecuteTime string `json:"nextExecuteTime,omitempty"` // StartTime: Optional. The time that the recurring schedule becomes effective. // Defaults to `create_time` of the patch deployment. StartTime string `json:"startTime,omitempty"` // TimeOfDay: Required. Time of the day to run a recurring deployment. TimeOfDay *TimeOfDay `json:"timeOfDay,omitempty"` // TimeZone: Required. Defines the time zone that `time_of_day` is relative to. // The rules for daylight saving time are determined by the chosen time zone. TimeZone *TimeZone `json:"timeZone,omitempty"` // Weekly: Required. Schedule with weekly executions. Weekly *WeeklySchedule `json:"weekly,omitempty"` // ForceSendFields is a list of field names (e.g. "EndTime") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "EndTime") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *RecurringSchedule) MarshalJSON() ([]byte, error) { type NoMethod RecurringSchedule return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // ResumePatchDeploymentRequest: A request message for resuming a patch // deployment. type ResumePatchDeploymentRequest struct { } // SoftwareRecipe: A software recipe is a set of instructions for installing // and configuring a piece of software. It consists of a set of artifacts that // are downloaded, and a set of steps that install, configure, and/or update // the software. Recipes support installing and updating software from // artifacts in the following formats: Zip archive, Tar archive, Windows MSI, // Debian package, and RPM package. Additionally, recipes support executing a // script (either defined in a file or directly in this api) in bash, sh, cmd, // and powershell. Updating a software recipe If a recipe is assigned to an // instance and there is a recipe with the same name but a lower version // already installed and the assigned state of the recipe is `UPDATED`, then // the recipe is updated to the new version. Script Working Directories Each // script or execution step is run in its own temporary directory which is // deleted after completing the step. type SoftwareRecipe struct { // Artifacts: Resources available to be used in the steps in the recipe. Artifacts []*SoftwareRecipeArtifact `json:"artifacts,omitempty"` // DesiredState: Default is INSTALLED. The desired state the agent should // maintain for this recipe. INSTALLED: The software recipe is installed on the // instance but won't be updated to new versions. UPDATED: The software recipe // is installed on the instance. The recipe is updated to a higher version, if // a higher version of the recipe is assigned to this instance. REMOVE: Remove // is unsupported for software recipes and attempts to create or update a // recipe to the REMOVE state is rejected. // // Possible values: // "DESIRED_STATE_UNSPECIFIED" - The default is to ensure the package is // installed. // "INSTALLED" - The agent ensures that the package is installed. // "UPDATED" - The agent ensures that the package is installed and // periodically checks for and install any updates. // "REMOVED" - The agent ensures that the package is not installed and // uninstall it if detected. DesiredState string `json:"desiredState,omitempty"` // InstallSteps: Actions to be taken for installing this recipe. On failure it // stops executing steps and does not attempt another installation. Any steps // taken (including partially completed steps) are not rolled back. InstallSteps []*SoftwareRecipeStep `json:"installSteps,omitempty"` // Name: Required. Unique identifier for the recipe. Only one recipe with a // given name is installed on an instance. Names are also used to identify // resources which helps to determine whether guest policies have conflicts. // This means that requests to create multiple recipes with the same name and // version are rejected since they could potentially have conflicting // assignments. Name string `json:"name,omitempty"` // UpdateSteps: Actions to be taken for updating this recipe. On failure it // stops executing steps and does not attempt another update for this recipe. // Any steps taken (including partially completed steps) are not rolled back. UpdateSteps []*SoftwareRecipeStep `json:"updateSteps,omitempty"` // Version: The version of this software recipe. Version can be up to 4 period // separated numbers (e.g. 12.34.56.78). Version string `json:"version,omitempty"` // ForceSendFields is a list of field names (e.g. "Artifacts") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Artifacts") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *SoftwareRecipe) MarshalJSON() ([]byte, error) { type NoMethod SoftwareRecipe return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // SoftwareRecipeArtifact: Specifies a resource to be used in the recipe. type SoftwareRecipeArtifact struct { // AllowInsecure: Defaults to false. When false, recipes are subject to // validations based on the artifact type: Remote: A checksum must be // specified, and only protocols with transport-layer security are permitted. // GCS: An object generation number must be specified. AllowInsecure bool `json:"allowInsecure,omitempty"` // Gcs: A Google Cloud Storage artifact. Gcs *SoftwareRecipeArtifactGcs `json:"gcs,omitempty"` // Id: Required. Id of the artifact, which the installation and update steps of // this recipe can reference. Artifacts in a recipe cannot have the same id. Id string `json:"id,omitempty"` // Remote: A generic remote artifact. Remote *SoftwareRecipeArtifactRemote `json:"remote,omitempty"` // ForceSendFields is a list of field names (e.g. "AllowInsecure") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "AllowInsecure") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *SoftwareRecipeArtifact) MarshalJSON() ([]byte, error) { type NoMethod SoftwareRecipeArtifact return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // SoftwareRecipeArtifactGcs: Specifies an artifact available as a Google Cloud // Storage object. type SoftwareRecipeArtifactGcs struct { // Bucket: Bucket of the Google Cloud Storage object. Given an example URL: // `https://storage.googleapis.com/my-bucket/foo/bar#1234567` this value would // be `my-bucket`. Bucket string `json:"bucket,omitempty"` // Generation: Must be provided if allow_insecure is false. Generation number // of the Google Cloud Storage object. // `https://storage.googleapis.com/my-bucket/foo/bar#1234567` this value would // be `1234567`. Generation int64 `json:"generation,omitempty,string"` // Object: Name of the Google Cloud Storage object. As specified [here] // (https://cloud.google.com/storage/docs/naming#objectnames) Given an example // URL: `https://storage.googleapis.com/my-bucket/foo/bar#1234567` this value // would be `foo/bar`. Object string `json:"object,omitempty"` // ForceSendFields is a list of field names (e.g. "Bucket") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Bucket") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *SoftwareRecipeArtifactGcs) MarshalJSON() ([]byte, error) { type NoMethod SoftwareRecipeArtifactGcs return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // SoftwareRecipeArtifactRemote: Specifies an artifact available via some URI. type SoftwareRecipeArtifactRemote struct { // Checksum: Must be provided if `allow_insecure` is `false`. SHA256 checksum // in hex format, to compare to the checksum of the artifact. If the checksum // is not empty and it doesn't match the artifact then the recipe installation // fails before running any of the steps. Checksum string `json:"checksum,omitempty"` // Uri: URI from which to fetch the object. It should contain both the protocol // and path following the format {protocol}://{location}. Uri string `json:"uri,omitempty"` // ForceSendFields is a list of field names (e.g. "Checksum") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Checksum") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *SoftwareRecipeArtifactRemote) MarshalJSON() ([]byte, error) { type NoMethod SoftwareRecipeArtifactRemote return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // SoftwareRecipeStep: An action that can be taken as part of installing or // updating a recipe. type SoftwareRecipeStep struct { // ArchiveExtraction: Extracts an archive into the specified directory. ArchiveExtraction *SoftwareRecipeStepExtractArchive `json:"archiveExtraction,omitempty"` // DpkgInstallation: Installs a deb file via dpkg. DpkgInstallation *SoftwareRecipeStepInstallDpkg `json:"dpkgInstallation,omitempty"` // FileCopy: Copies a file onto the instance. FileCopy *SoftwareRecipeStepCopyFile `json:"fileCopy,omitempty"` // FileExec: Executes an artifact or local file. FileExec *SoftwareRecipeStepExecFile `json:"fileExec,omitempty"` // MsiInstallation: Installs an MSI file. MsiInstallation *SoftwareRecipeStepInstallMsi `json:"msiInstallation,omitempty"` // RpmInstallation: Installs an rpm file via the rpm utility. RpmInstallation *SoftwareRecipeStepInstallRpm `json:"rpmInstallation,omitempty"` // ScriptRun: Runs commands in a shell. ScriptRun *SoftwareRecipeStepRunScript `json:"scriptRun,omitempty"` // ForceSendFields is a list of field names (e.g. "ArchiveExtraction") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "ArchiveExtraction") to include in // API requests with the JSON null value. By default, fields with empty values // are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *SoftwareRecipeStep) MarshalJSON() ([]byte, error) { type NoMethod SoftwareRecipeStep return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // SoftwareRecipeStepCopyFile: Copies the artifact to the specified path on the // instance. type SoftwareRecipeStepCopyFile struct { // ArtifactId: Required. The id of the relevant artifact in the recipe. ArtifactId string `json:"artifactId,omitempty"` // Destination: Required. The absolute path on the instance to put the file. Destination string `json:"destination,omitempty"` // Overwrite: Whether to allow this step to overwrite existing files. If this // is false and the file already exists the file is not overwritten and the // step is considered a success. Defaults to false. Overwrite bool `json:"overwrite,omitempty"` // Permissions: Consists of three octal digits which represent, in order, the // permissions of the owner, group, and other users for the file (similarly to // the numeric mode used in the linux chmod utility). Each digit represents a // three bit number with the 4 bit corresponding to the read permissions, the 2 // bit corresponds to the write bit, and the one bit corresponds to the execute // permission. Default behavior is 755. Below are some examples of permissions // and their associated values: read, write, and execute: 7 read and execute: 5 // read and write: 6 read only: 4 Permissions string `json:"permissions,omitempty"` // ForceSendFields is a list of field names (e.g. "ArtifactId") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "ArtifactId") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *SoftwareRecipeStepCopyFile) MarshalJSON() ([]byte, error) { type NoMethod SoftwareRecipeStepCopyFile return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // SoftwareRecipeStepExecFile: Executes an artifact or local file. type SoftwareRecipeStepExecFile struct { // AllowedExitCodes: Defaults to [0]. A list of possible return values that the // program can return to indicate a success. AllowedExitCodes []int64 `json:"allowedExitCodes,omitempty"` // Args: Arguments to be passed to the provided executable. Args []string `json:"args,omitempty"` // ArtifactId: The id of the relevant artifact in the recipe. ArtifactId string `json:"artifactId,omitempty"` // LocalPath: The absolute path of the file on the local filesystem. LocalPath string `json:"localPath,omitempty"` // ForceSendFields is a list of field names (e.g. "AllowedExitCodes") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "AllowedExitCodes") to include in // API requests with the JSON null value. By default, fields with empty values // are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *SoftwareRecipeStepExecFile) MarshalJSON() ([]byte, error) { type NoMethod SoftwareRecipeStepExecFile return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // SoftwareRecipeStepExtractArchive: Extracts an archive of the type specified // in the specified directory. type SoftwareRecipeStepExtractArchive struct { // ArtifactId: Required. The id of the relevant artifact in the recipe. ArtifactId string `json:"artifactId,omitempty"` // Destination: Directory to extract archive to. Defaults to `/` on Linux or // `C:\` on Windows. Destination string `json:"destination,omitempty"` // Type: Required. The type of the archive to extract. // // Possible values: // "ARCHIVE_TYPE_UNSPECIFIED" - Indicates that the archive type isn't // specified. // "TAR" - Indicates that the archive is a tar archive with no encryption. // "TAR_GZIP" - Indicates that the archive is a tar archive with gzip // encryption. // "TAR_BZIP" - Indicates that the archive is a tar archive with bzip // encryption. // "TAR_LZMA" - Indicates that the archive is a tar archive with lzma // encryption. // "TAR_XZ" - Indicates that the archive is a tar archive with xz encryption. // "ZIP" - Indicates that the archive is a zip archive. Type string `json:"type,omitempty"` // ForceSendFields is a list of field names (e.g. "ArtifactId") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "ArtifactId") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *SoftwareRecipeStepExtractArchive) MarshalJSON() ([]byte, error) { type NoMethod SoftwareRecipeStepExtractArchive return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // SoftwareRecipeStepInstallDpkg: Installs a deb via dpkg. type SoftwareRecipeStepInstallDpkg struct { // ArtifactId: Required. The id of the relevant artifact in the recipe. ArtifactId string `json:"artifactId,omitempty"` // ForceSendFields is a list of field names (e.g. "ArtifactId") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "ArtifactId") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *SoftwareRecipeStepInstallDpkg) MarshalJSON() ([]byte, error) { type NoMethod SoftwareRecipeStepInstallDpkg return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // SoftwareRecipeStepInstallMsi: Installs an MSI file. type SoftwareRecipeStepInstallMsi struct { // AllowedExitCodes: Return codes that indicate that the software installed or // updated successfully. Behaviour defaults to [0] AllowedExitCodes []int64 `json:"allowedExitCodes,omitempty"` // ArtifactId: Required. The id of the relevant artifact in the recipe. ArtifactId string `json:"artifactId,omitempty"` // Flags: The flags to use when installing the MSI defaults to ["/i"] (i.e. the // install flag). Flags []string `json:"flags,omitempty"` // ForceSendFields is a list of field names (e.g. "AllowedExitCodes") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "AllowedExitCodes") to include in // API requests with the JSON null value. By default, fields with empty values // are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *SoftwareRecipeStepInstallMsi) MarshalJSON() ([]byte, error) { type NoMethod SoftwareRecipeStepInstallMsi return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // SoftwareRecipeStepInstallRpm: Installs an rpm file via the rpm utility. type SoftwareRecipeStepInstallRpm struct { // ArtifactId: Required. The id of the relevant artifact in the recipe. ArtifactId string `json:"artifactId,omitempty"` // ForceSendFields is a list of field names (e.g. "ArtifactId") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "ArtifactId") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *SoftwareRecipeStepInstallRpm) MarshalJSON() ([]byte, error) { type NoMethod SoftwareRecipeStepInstallRpm return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // SoftwareRecipeStepRunScript: Runs a script through an interpreter. type SoftwareRecipeStepRunScript struct { // AllowedExitCodes: Return codes that indicate that the software installed or // updated successfully. Behaviour defaults to [0] AllowedExitCodes []int64 `json:"allowedExitCodes,omitempty"` // Interpreter: The script interpreter to use to run the script. If no // interpreter is specified the script is executed directly, which likely only // succeed for scripts with shebang lines // (https://en.wikipedia.org/wiki/Shebang_\(Unix\)). // // Possible values: // "INTERPRETER_UNSPECIFIED" - Default value for ScriptType. // "SHELL" - Indicates that the script is run with `/bin/sh` on Linux and // `cmd` on windows. // "POWERSHELL" - Indicates that the script is run with powershell. Interpreter string `json:"interpreter,omitempty"` // Script: Required. The shell script to be executed. Script string `json:"script,omitempty"` // ForceSendFields is a list of field names (e.g. "AllowedExitCodes") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "AllowedExitCodes") to include in // API requests with the JSON null value. By default, fields with empty values // are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *SoftwareRecipeStepRunScript) MarshalJSON() ([]byte, error) { type NoMethod SoftwareRecipeStepRunScript return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // TimeOfDay: Represents a time of day. The date and time zone are either not // significant or are specified elsewhere. An API may choose to allow leap // seconds. Related types are google.type.Date and `google.protobuf.Timestamp`. type TimeOfDay struct { // Hours: Hours of day in 24 hour format. Should be from 0 to 23. An API may // choose to allow the value "24:00:00" for scenarios like business closing // time. Hours int64 `json:"hours,omitempty"` // Minutes: Minutes of hour of day. Must be from 0 to 59. Minutes int64 `json:"minutes,omitempty"` // Nanos: Fractions of seconds in nanoseconds. Must be from 0 to 999,999,999. Nanos int64 `json:"nanos,omitempty"` // Seconds: Seconds of minutes of the time. Must normally be from 0 to 59. An // API may allow the value 60 if it allows leap-seconds. Seconds int64 `json:"seconds,omitempty"` // ForceSendFields is a list of field names (e.g. "Hours") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Hours") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *TimeOfDay) MarshalJSON() ([]byte, error) { type NoMethod TimeOfDay return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // TimeZone: Represents a time zone from the IANA Time Zone Database // (https://www.iana.org/time-zones). type TimeZone struct { // Id: IANA Time Zone Database time zone, e.g. "America/New_York". Id string `json:"id,omitempty"` // Version: Optional. IANA Time Zone Database version number, e.g. "2019a". Version string `json:"version,omitempty"` // ForceSendFields is a list of field names (e.g. "Id") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Id") to include in API requests // with the JSON null value. By default, fields with empty values are omitted // from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *TimeZone) MarshalJSON() ([]byte, error) { type NoMethod TimeZone return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // WeekDayOfMonth: Represents one week day in a month. An example is "the 4th // Sunday". type WeekDayOfMonth struct { // DayOfWeek: Required. A day of the week. // // Possible values: // "DAY_OF_WEEK_UNSPECIFIED" - The day of the week is unspecified. // "MONDAY" - Monday // "TUESDAY" - Tuesday // "WEDNESDAY" - Wednesday // "THURSDAY" - Thursday // "FRIDAY" - Friday // "SATURDAY" - Saturday // "SUNDAY" - Sunday DayOfWeek string `json:"dayOfWeek,omitempty"` // DayOffset: Optional. Represents the number of days before or after the given // week day of month that the patch deployment is scheduled for. For example if // `week_ordinal` and `day_of_week` values point to the second day of the month // and this `day_offset` value is set to `3`, the patch deployment takes place // three days after the second Tuesday of the month. If this value is negative, // for example -5, the patches are deployed five days before before the second // Tuesday of the month. Allowed values are in range [-30, 30]. DayOffset int64 `json:"dayOffset,omitempty"` // WeekOrdinal: Required. Week number in a month. 1-4 indicates the 1st to 4th // week of the month. -1 indicates the last week of the month. WeekOrdinal int64 `json:"weekOrdinal,omitempty"` // ForceSendFields is a list of field names (e.g. "DayOfWeek") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "DayOfWeek") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *WeekDayOfMonth) MarshalJSON() ([]byte, error) { type NoMethod WeekDayOfMonth return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // WeeklySchedule: Represents a weekly schedule. type WeeklySchedule struct { // DayOfWeek: Required. Day of the week. // // Possible values: // "DAY_OF_WEEK_UNSPECIFIED" - The day of the week is unspecified. // "MONDAY" - Monday // "TUESDAY" - Tuesday // "WEDNESDAY" - Wednesday // "THURSDAY" - Thursday // "FRIDAY" - Friday // "SATURDAY" - Saturday // "SUNDAY" - Sunday DayOfWeek string `json:"dayOfWeek,omitempty"` // ForceSendFields is a list of field names (e.g. "DayOfWeek") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "DayOfWeek") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *WeeklySchedule) MarshalJSON() ([]byte, error) { type NoMethod WeeklySchedule return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // WindowsUpdateSettings: Windows patching is performed using the Windows // Update Agent. type WindowsUpdateSettings struct { // Classifications: Only apply updates of these windows update classifications. // If empty, all updates are applied. // // Possible values: // "CLASSIFICATION_UNSPECIFIED" - Invalid. If classifications are included, // they must be specified. // "CRITICAL" - "A widely released fix for a specific problem that addresses // a critical, non-security-related bug." [1] // "SECURITY" - "A widely released fix for a product-specific, // security-related vulnerability. Security vulnerabilities are rated by their // severity. The severity rating is indicated in the Microsoft security // bulletin as critical, important, moderate, or low." [1] // "DEFINITION" - "A widely released and frequent software update that // contains additions to a product's definition database. Definition databases // are often used to detect objects that have specific attributes, such as // malicious code, phishing websites, or junk mail." [1] // "DRIVER" - "Software that controls the input and output of a device." [1] // "FEATURE_PACK" - "New product functionality that is first distributed // outside the context of a product release and that is typically included in // the next full product release." [1] // "SERVICE_PACK" - "A tested, cumulative set of all hotfixes, security // updates, critical updates, and updates. Additionally, service packs may // contain additional fixes for problems that are found internally since the // release of the product. Service packs my also contain a limited number of // customer-requested design changes or features." [1] // "TOOL" - "A utility or feature that helps complete a task or set of // tasks." [1] // "UPDATE_ROLLUP" - "A tested, cumulative set of hotfixes, security updates, // critical updates, and updates that are packaged together for easy // deployment. A rollup generally targets a specific area, such as security, or // a component of a product, such as Internet Information Services (IIS)." [1] // "UPDATE" - "A widely released fix for a specific problem. An update // addresses a noncritical, non-security-related bug." [1] Classifications []string `json:"classifications,omitempty"` // Excludes: List of KBs to exclude from update. Excludes []string `json:"excludes,omitempty"` // ExclusivePatches: An exclusive list of kbs to be updated. These are the only // patches that will be updated. This field must not be used with other patch // configurations. ExclusivePatches []string `json:"exclusivePatches,omitempty"` // ForceSendFields is a list of field names (e.g. "Classifications") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Classifications") to include in // API requests with the JSON null value. By default, fields with empty values // are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *WindowsUpdateSettings) MarshalJSON() ([]byte, error) { type NoMethod WindowsUpdateSettings return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // YumRepository: Represents a single Yum package repository. This repository // is added to a repo file that is stored at // `/etc/yum.repos.d/google_osconfig.repo`. type YumRepository struct { // BaseUrl: Required. The location of the repository directory. BaseUrl string `json:"baseUrl,omitempty"` // DisplayName: The display name of the repository. DisplayName string `json:"displayName,omitempty"` // GpgKeys: URIs of GPG keys. GpgKeys []string `json:"gpgKeys,omitempty"` // Id: Required. A one word, unique name for this repository. This is the `repo // id` in the Yum config file and also the `display_name` if `display_name` is // omitted. This id is also used as the unique identifier when checking for // guest policy conflicts. Id string `json:"id,omitempty"` // ForceSendFields is a list of field names (e.g. "BaseUrl") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "BaseUrl") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *YumRepository) MarshalJSON() ([]byte, error) { type NoMethod YumRepository return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // YumSettings: Yum patching is performed by executing `yum update`. Additional // options can be set to control how this is executed. Note that not all // settings are supported on all platforms. type YumSettings struct { // Excludes: List of packages to exclude from update. These packages are // excluded by using the yum `--exclude` flag. Excludes []string `json:"excludes,omitempty"` // ExclusivePackages: An exclusive list of packages to be updated. These are // the only packages that will be updated. If these packages are not installed, // they will be ignored. This field must not be specified with any other patch // configuration fields. ExclusivePackages []string `json:"exclusivePackages,omitempty"` // Minimal: Will cause patch to run `yum update-minimal` instead. Minimal bool `json:"minimal,omitempty"` // Security: Adds the `--security` flag to `yum update`. Not supported on all // platforms. Security bool `json:"security,omitempty"` // ForceSendFields is a list of field names (e.g. "Excludes") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Excludes") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *YumSettings) MarshalJSON() ([]byte, error) { type NoMethod YumSettings return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // ZypperRepository: Represents a single Zypper package repository. This // repository is added to a repo file that is stored at // `/etc/zypp/repos.d/google_osconfig.repo`. type ZypperRepository struct { // BaseUrl: Required. The location of the repository directory. BaseUrl string `json:"baseUrl,omitempty"` // DisplayName: The display name of the repository. DisplayName string `json:"displayName,omitempty"` // GpgKeys: URIs of GPG keys. GpgKeys []string `json:"gpgKeys,omitempty"` // Id: Required. A one word, unique name for this repository. This is the `repo // id` in the zypper config file and also the `display_name` if `display_name` // is omitted. This id is also used as the unique identifier when checking for // guest policy conflicts. Id string `json:"id,omitempty"` // ForceSendFields is a list of field names (e.g. "BaseUrl") to unconditionally // include in API requests. By default, fields with empty or default values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "BaseUrl") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *ZypperRepository) MarshalJSON() ([]byte, error) { type NoMethod ZypperRepository return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } // ZypperSettings: Zypper patching is performed by running `zypper patch`. See // also https://en.opensuse.org/SDB:Zypper_manual. type ZypperSettings struct { // Categories: Install only patches with these categories. Common categories // include security, recommended, and feature. Categories []string `json:"categories,omitempty"` // Excludes: List of patches to exclude from update. Excludes []string `json:"excludes,omitempty"` // ExclusivePatches: An exclusive list of patches to be updated. These are the // only patches that will be installed using 'zypper patch patch:' command. // This field must not be used with any other patch configuration fields. ExclusivePatches []string `json:"exclusivePatches,omitempty"` // Severities: Install only patches with these severities. Common severities // include critical, important, moderate, and low. Severities []string `json:"severities,omitempty"` // WithOptional: Adds the `--with-optional` flag to `zypper patch`. WithOptional bool `json:"withOptional,omitempty"` // WithUpdate: Adds the `--with-update` flag, to `zypper patch`. WithUpdate bool `json:"withUpdate,omitempty"` // ForceSendFields is a list of field names (e.g. "Categories") to // unconditionally include in API requests. By default, fields with empty or // default values are omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-ForceSendFields for more // details. ForceSendFields []string `json:"-"` // NullFields is a list of field names (e.g. "Categories") to include in API // requests with the JSON null value. By default, fields with empty values are // omitted from API requests. See // https://pkg.go.dev/google.golang.org/api#hdr-NullFields for more details. NullFields []string `json:"-"` } func (s *ZypperSettings) MarshalJSON() ([]byte, error) { type NoMethod ZypperSettings return gensupport.MarshalJSON(NoMethod(*s), s.ForceSendFields, s.NullFields) } type ProjectsGuestPoliciesCreateCall struct { s *Service parent string guestpolicy *GuestPolicy urlParams_ gensupport.URLParams ctx_ context.Context header_ http.Header } // Create: Create an OS Config guest policy. // // - parent: The resource name of the parent using one of the following forms: // `projects/{project_number}`. func (r *ProjectsGuestPoliciesService) Create(parent string, guestpolicy *GuestPolicy) *ProjectsGuestPoliciesCreateCall { c := &ProjectsGuestPoliciesCreateCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.parent = parent c.guestpolicy = guestpolicy return c } // GuestPolicyId sets the optional parameter "guestPolicyId": Required. The // logical name of the guest policy in the project with the following // restrictions: * Must contain only lowercase letters, numbers, and hyphens. * // Must start with a letter. * Must be between 1-63 characters. * Must end with // a number or a letter. * Must be unique within the project. func (c *ProjectsGuestPoliciesCreateCall) GuestPolicyId(guestPolicyId string) *ProjectsGuestPoliciesCreateCall { c.urlParams_.Set("guestPolicyId", guestPolicyId) return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsGuestPoliciesCreateCall) Fields(s ...googleapi.Field) *ProjectsGuestPoliciesCreateCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsGuestPoliciesCreateCall) Context(ctx context.Context) *ProjectsGuestPoliciesCreateCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsGuestPoliciesCreateCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsGuestPoliciesCreateCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "application/json", c.header_) var body io.Reader = nil body, err := googleapi.WithoutDataWrapper.JSONReader(c.guestpolicy) if err != nil { return nil, err } c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+parent}/guestPolicies") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("POST", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "parent": c.parent, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.guestPolicies.create" call. // Any non-2xx status code is an error. Response headers are in either // *GuestPolicy.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 (c *ProjectsGuestPoliciesCreateCall) Do(opts ...googleapi.CallOption) (*GuestPolicy, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &GuestPolicy{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } type ProjectsGuestPoliciesDeleteCall struct { s *Service name string urlParams_ gensupport.URLParams ctx_ context.Context header_ http.Header } // Delete: Delete an OS Config guest policy. // // - name: The resource name of the guest policy using one of the following // forms: `projects/{project_number}/guestPolicies/{guest_policy_id}`. func (r *ProjectsGuestPoliciesService) Delete(name string) *ProjectsGuestPoliciesDeleteCall { c := &ProjectsGuestPoliciesDeleteCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.name = name return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsGuestPoliciesDeleteCall) Fields(s ...googleapi.Field) *ProjectsGuestPoliciesDeleteCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsGuestPoliciesDeleteCall) Context(ctx context.Context) *ProjectsGuestPoliciesDeleteCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsGuestPoliciesDeleteCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsGuestPoliciesDeleteCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "", c.header_) var body io.Reader = nil c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+name}") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("DELETE", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "name": c.name, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.guestPolicies.delete" call. // 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 (c *ProjectsGuestPoliciesDeleteCall) Do(opts ...googleapi.CallOption) (*Empty, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &Empty{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } type ProjectsGuestPoliciesGetCall struct { s *Service name string urlParams_ gensupport.URLParams ifNoneMatch_ string ctx_ context.Context header_ http.Header } // Get: Get an OS Config guest policy. // // - name: The resource name of the guest policy using one of the following // forms: `projects/{project_number}/guestPolicies/{guest_policy_id}`. func (r *ProjectsGuestPoliciesService) Get(name string) *ProjectsGuestPoliciesGetCall { c := &ProjectsGuestPoliciesGetCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.name = name return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsGuestPoliciesGetCall) Fields(s ...googleapi.Field) *ProjectsGuestPoliciesGetCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // IfNoneMatch sets an 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. func (c *ProjectsGuestPoliciesGetCall) IfNoneMatch(entityTag string) *ProjectsGuestPoliciesGetCall { c.ifNoneMatch_ = entityTag return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsGuestPoliciesGetCall) Context(ctx context.Context) *ProjectsGuestPoliciesGetCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsGuestPoliciesGetCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsGuestPoliciesGetCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "", c.header_) if c.ifNoneMatch_ != "" { reqHeaders.Set("If-None-Match", c.ifNoneMatch_) } var body io.Reader = nil c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+name}") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("GET", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "name": c.name, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.guestPolicies.get" call. // Any non-2xx status code is an error. Response headers are in either // *GuestPolicy.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 (c *ProjectsGuestPoliciesGetCall) Do(opts ...googleapi.CallOption) (*GuestPolicy, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &GuestPolicy{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } type ProjectsGuestPoliciesListCall struct { s *Service parent string urlParams_ gensupport.URLParams ifNoneMatch_ string ctx_ context.Context header_ http.Header } // List: Get a page of OS Config guest policies. // // - parent: The resource name of the parent using one of the following forms: // `projects/{project_number}`. func (r *ProjectsGuestPoliciesService) List(parent string) *ProjectsGuestPoliciesListCall { c := &ProjectsGuestPoliciesListCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.parent = parent return c } // PageSize sets the optional parameter "pageSize": The maximum number of guest // policies to return. func (c *ProjectsGuestPoliciesListCall) PageSize(pageSize int64) *ProjectsGuestPoliciesListCall { c.urlParams_.Set("pageSize", fmt.Sprint(pageSize)) return c } // PageToken sets the optional parameter "pageToken": A pagination token // returned from a previous call to `ListGuestPolicies` that indicates where // this listing should continue from. func (c *ProjectsGuestPoliciesListCall) PageToken(pageToken string) *ProjectsGuestPoliciesListCall { c.urlParams_.Set("pageToken", pageToken) return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsGuestPoliciesListCall) Fields(s ...googleapi.Field) *ProjectsGuestPoliciesListCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // IfNoneMatch sets an 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. func (c *ProjectsGuestPoliciesListCall) IfNoneMatch(entityTag string) *ProjectsGuestPoliciesListCall { c.ifNoneMatch_ = entityTag return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsGuestPoliciesListCall) Context(ctx context.Context) *ProjectsGuestPoliciesListCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsGuestPoliciesListCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsGuestPoliciesListCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "", c.header_) if c.ifNoneMatch_ != "" { reqHeaders.Set("If-None-Match", c.ifNoneMatch_) } var body io.Reader = nil c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+parent}/guestPolicies") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("GET", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "parent": c.parent, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.guestPolicies.list" call. // Any non-2xx status code is an error. Response headers are in either // *ListGuestPoliciesResponse.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 (c *ProjectsGuestPoliciesListCall) Do(opts ...googleapi.CallOption) (*ListGuestPoliciesResponse, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &ListGuestPoliciesResponse{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } // 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. func (c *ProjectsGuestPoliciesListCall) Pages(ctx context.Context, f func(*ListGuestPoliciesResponse) error) error { c.ctx_ = ctx defer c.PageToken(c.urlParams_.Get("pageToken")) for { x, err := c.Do() if err != nil { return err } if err := f(x); err != nil { return err } if x.NextPageToken == "" { return nil } c.PageToken(x.NextPageToken) } } type ProjectsGuestPoliciesPatchCall struct { s *Service name string guestpolicy *GuestPolicy urlParams_ gensupport.URLParams ctx_ context.Context header_ http.Header } // Patch: Update an OS Config guest policy. // // - name: Unique name of the resource in this project using one of the // following forms: // `projects/{project_number}/guestPolicies/{guest_policy_id}`. func (r *ProjectsGuestPoliciesService) Patch(name string, guestpolicy *GuestPolicy) *ProjectsGuestPoliciesPatchCall { c := &ProjectsGuestPoliciesPatchCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.name = name c.guestpolicy = guestpolicy return c } // UpdateMask sets the optional parameter "updateMask": Field mask that // controls which fields of the guest policy should be updated. func (c *ProjectsGuestPoliciesPatchCall) UpdateMask(updateMask string) *ProjectsGuestPoliciesPatchCall { c.urlParams_.Set("updateMask", updateMask) return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsGuestPoliciesPatchCall) Fields(s ...googleapi.Field) *ProjectsGuestPoliciesPatchCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsGuestPoliciesPatchCall) Context(ctx context.Context) *ProjectsGuestPoliciesPatchCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsGuestPoliciesPatchCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsGuestPoliciesPatchCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "application/json", c.header_) var body io.Reader = nil body, err := googleapi.WithoutDataWrapper.JSONReader(c.guestpolicy) if err != nil { return nil, err } c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+name}") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("PATCH", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "name": c.name, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.guestPolicies.patch" call. // Any non-2xx status code is an error. Response headers are in either // *GuestPolicy.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 (c *ProjectsGuestPoliciesPatchCall) Do(opts ...googleapi.CallOption) (*GuestPolicy, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &GuestPolicy{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } type ProjectsPatchDeploymentsCreateCall struct { s *Service parent string patchdeployment *PatchDeployment urlParams_ gensupport.URLParams ctx_ context.Context header_ http.Header } // Create: Create an OS Config patch deployment. // // - parent: The project to apply this patch deployment to in the form // `projects/*`. func (r *ProjectsPatchDeploymentsService) Create(parent string, patchdeployment *PatchDeployment) *ProjectsPatchDeploymentsCreateCall { c := &ProjectsPatchDeploymentsCreateCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.parent = parent c.patchdeployment = patchdeployment return c } // PatchDeploymentId sets the optional parameter "patchDeploymentId": Required. // A name for the patch deployment in the project. When creating a name the // following rules apply: * Must contain only lowercase letters, numbers, and // hyphens. * Must start with a letter. * Must be between 1-63 characters. * // Must end with a number or a letter. * Must be unique within the project. func (c *ProjectsPatchDeploymentsCreateCall) PatchDeploymentId(patchDeploymentId string) *ProjectsPatchDeploymentsCreateCall { c.urlParams_.Set("patchDeploymentId", patchDeploymentId) return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsPatchDeploymentsCreateCall) Fields(s ...googleapi.Field) *ProjectsPatchDeploymentsCreateCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsPatchDeploymentsCreateCall) Context(ctx context.Context) *ProjectsPatchDeploymentsCreateCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsPatchDeploymentsCreateCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsPatchDeploymentsCreateCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "application/json", c.header_) var body io.Reader = nil body, err := googleapi.WithoutDataWrapper.JSONReader(c.patchdeployment) if err != nil { return nil, err } c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+parent}/patchDeployments") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("POST", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "parent": c.parent, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.patchDeployments.create" call. // Any non-2xx status code is an error. Response headers are in either // *PatchDeployment.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 (c *ProjectsPatchDeploymentsCreateCall) Do(opts ...googleapi.CallOption) (*PatchDeployment, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &PatchDeployment{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } type ProjectsPatchDeploymentsDeleteCall struct { s *Service name string urlParams_ gensupport.URLParams ctx_ context.Context header_ http.Header } // Delete: Delete an OS Config patch deployment. // // - name: The resource name of the patch deployment in the form // `projects/*/patchDeployments/*`. func (r *ProjectsPatchDeploymentsService) Delete(name string) *ProjectsPatchDeploymentsDeleteCall { c := &ProjectsPatchDeploymentsDeleteCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.name = name return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsPatchDeploymentsDeleteCall) Fields(s ...googleapi.Field) *ProjectsPatchDeploymentsDeleteCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsPatchDeploymentsDeleteCall) Context(ctx context.Context) *ProjectsPatchDeploymentsDeleteCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsPatchDeploymentsDeleteCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsPatchDeploymentsDeleteCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "", c.header_) var body io.Reader = nil c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+name}") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("DELETE", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "name": c.name, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.patchDeployments.delete" call. // 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 (c *ProjectsPatchDeploymentsDeleteCall) Do(opts ...googleapi.CallOption) (*Empty, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &Empty{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } type ProjectsPatchDeploymentsGetCall struct { s *Service name string urlParams_ gensupport.URLParams ifNoneMatch_ string ctx_ context.Context header_ http.Header } // Get: Get an OS Config patch deployment. // // - name: The resource name of the patch deployment in the form // `projects/*/patchDeployments/*`. func (r *ProjectsPatchDeploymentsService) Get(name string) *ProjectsPatchDeploymentsGetCall { c := &ProjectsPatchDeploymentsGetCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.name = name return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsPatchDeploymentsGetCall) Fields(s ...googleapi.Field) *ProjectsPatchDeploymentsGetCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // IfNoneMatch sets an 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. func (c *ProjectsPatchDeploymentsGetCall) IfNoneMatch(entityTag string) *ProjectsPatchDeploymentsGetCall { c.ifNoneMatch_ = entityTag return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsPatchDeploymentsGetCall) Context(ctx context.Context) *ProjectsPatchDeploymentsGetCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsPatchDeploymentsGetCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsPatchDeploymentsGetCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "", c.header_) if c.ifNoneMatch_ != "" { reqHeaders.Set("If-None-Match", c.ifNoneMatch_) } var body io.Reader = nil c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+name}") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("GET", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "name": c.name, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.patchDeployments.get" call. // Any non-2xx status code is an error. Response headers are in either // *PatchDeployment.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 (c *ProjectsPatchDeploymentsGetCall) Do(opts ...googleapi.CallOption) (*PatchDeployment, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &PatchDeployment{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } type ProjectsPatchDeploymentsListCall struct { s *Service parent string urlParams_ gensupport.URLParams ifNoneMatch_ string ctx_ context.Context header_ http.Header } // List: Get a page of OS Config patch deployments. // // - parent: The resource name of the parent in the form `projects/*`. func (r *ProjectsPatchDeploymentsService) List(parent string) *ProjectsPatchDeploymentsListCall { c := &ProjectsPatchDeploymentsListCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.parent = parent return c } // PageSize sets the optional parameter "pageSize": The maximum number of patch // deployments to return. Default is 100. func (c *ProjectsPatchDeploymentsListCall) PageSize(pageSize int64) *ProjectsPatchDeploymentsListCall { c.urlParams_.Set("pageSize", fmt.Sprint(pageSize)) return c } // PageToken sets the optional parameter "pageToken": A pagination token // returned from a previous call to ListPatchDeployments that indicates where // this listing should continue from. func (c *ProjectsPatchDeploymentsListCall) PageToken(pageToken string) *ProjectsPatchDeploymentsListCall { c.urlParams_.Set("pageToken", pageToken) return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsPatchDeploymentsListCall) Fields(s ...googleapi.Field) *ProjectsPatchDeploymentsListCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // IfNoneMatch sets an 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. func (c *ProjectsPatchDeploymentsListCall) IfNoneMatch(entityTag string) *ProjectsPatchDeploymentsListCall { c.ifNoneMatch_ = entityTag return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsPatchDeploymentsListCall) Context(ctx context.Context) *ProjectsPatchDeploymentsListCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsPatchDeploymentsListCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsPatchDeploymentsListCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "", c.header_) if c.ifNoneMatch_ != "" { reqHeaders.Set("If-None-Match", c.ifNoneMatch_) } var body io.Reader = nil c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+parent}/patchDeployments") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("GET", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "parent": c.parent, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.patchDeployments.list" call. // Any non-2xx status code is an error. Response headers are in either // *ListPatchDeploymentsResponse.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 (c *ProjectsPatchDeploymentsListCall) Do(opts ...googleapi.CallOption) (*ListPatchDeploymentsResponse, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &ListPatchDeploymentsResponse{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } // 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. func (c *ProjectsPatchDeploymentsListCall) Pages(ctx context.Context, f func(*ListPatchDeploymentsResponse) error) error { c.ctx_ = ctx defer c.PageToken(c.urlParams_.Get("pageToken")) for { x, err := c.Do() if err != nil { return err } if err := f(x); err != nil { return err } if x.NextPageToken == "" { return nil } c.PageToken(x.NextPageToken) } } type ProjectsPatchDeploymentsPatchCall struct { s *Service name string patchdeployment *PatchDeployment urlParams_ gensupport.URLParams ctx_ context.Context header_ http.Header } // Patch: Update an OS Config patch deployment. // // - name: Unique name for the patch deployment resource in a project. The // patch deployment name is in the form: // `projects/{project_id}/patchDeployments/{patch_deployment_id}`. This field // is ignored when you create a new patch deployment. func (r *ProjectsPatchDeploymentsService) Patch(name string, patchdeployment *PatchDeployment) *ProjectsPatchDeploymentsPatchCall { c := &ProjectsPatchDeploymentsPatchCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.name = name c.patchdeployment = patchdeployment return c } // UpdateMask sets the optional parameter "updateMask": Field mask that // controls which fields of the patch deployment should be updated. func (c *ProjectsPatchDeploymentsPatchCall) UpdateMask(updateMask string) *ProjectsPatchDeploymentsPatchCall { c.urlParams_.Set("updateMask", updateMask) return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsPatchDeploymentsPatchCall) Fields(s ...googleapi.Field) *ProjectsPatchDeploymentsPatchCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsPatchDeploymentsPatchCall) Context(ctx context.Context) *ProjectsPatchDeploymentsPatchCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsPatchDeploymentsPatchCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsPatchDeploymentsPatchCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "application/json", c.header_) var body io.Reader = nil body, err := googleapi.WithoutDataWrapper.JSONReader(c.patchdeployment) if err != nil { return nil, err } c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+name}") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("PATCH", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "name": c.name, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.patchDeployments.patch" call. // Any non-2xx status code is an error. Response headers are in either // *PatchDeployment.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 (c *ProjectsPatchDeploymentsPatchCall) Do(opts ...googleapi.CallOption) (*PatchDeployment, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &PatchDeployment{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } type ProjectsPatchDeploymentsPauseCall struct { s *Service name string pausepatchdeploymentrequest *PausePatchDeploymentRequest urlParams_ gensupport.URLParams ctx_ context.Context header_ http.Header } // Pause: Change state of patch deployment to "PAUSED". Patch deployment in // paused state doesn't generate patch jobs. // // - name: The resource name of the patch deployment in the form // `projects/*/patchDeployments/*`. func (r *ProjectsPatchDeploymentsService) Pause(name string, pausepatchdeploymentrequest *PausePatchDeploymentRequest) *ProjectsPatchDeploymentsPauseCall { c := &ProjectsPatchDeploymentsPauseCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.name = name c.pausepatchdeploymentrequest = pausepatchdeploymentrequest return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsPatchDeploymentsPauseCall) Fields(s ...googleapi.Field) *ProjectsPatchDeploymentsPauseCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsPatchDeploymentsPauseCall) Context(ctx context.Context) *ProjectsPatchDeploymentsPauseCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsPatchDeploymentsPauseCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsPatchDeploymentsPauseCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "application/json", c.header_) var body io.Reader = nil body, err := googleapi.WithoutDataWrapper.JSONReader(c.pausepatchdeploymentrequest) if err != nil { return nil, err } c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+name}:pause") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("POST", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "name": c.name, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.patchDeployments.pause" call. // Any non-2xx status code is an error. Response headers are in either // *PatchDeployment.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 (c *ProjectsPatchDeploymentsPauseCall) Do(opts ...googleapi.CallOption) (*PatchDeployment, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &PatchDeployment{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } type ProjectsPatchDeploymentsResumeCall struct { s *Service name string resumepatchdeploymentrequest *ResumePatchDeploymentRequest urlParams_ gensupport.URLParams ctx_ context.Context header_ http.Header } // Resume: Change state of patch deployment back to "ACTIVE". Patch deployment // in active state continues to generate patch jobs. // // - name: The resource name of the patch deployment in the form // `projects/*/patchDeployments/*`. func (r *ProjectsPatchDeploymentsService) Resume(name string, resumepatchdeploymentrequest *ResumePatchDeploymentRequest) *ProjectsPatchDeploymentsResumeCall { c := &ProjectsPatchDeploymentsResumeCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.name = name c.resumepatchdeploymentrequest = resumepatchdeploymentrequest return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsPatchDeploymentsResumeCall) Fields(s ...googleapi.Field) *ProjectsPatchDeploymentsResumeCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsPatchDeploymentsResumeCall) Context(ctx context.Context) *ProjectsPatchDeploymentsResumeCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsPatchDeploymentsResumeCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsPatchDeploymentsResumeCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "application/json", c.header_) var body io.Reader = nil body, err := googleapi.WithoutDataWrapper.JSONReader(c.resumepatchdeploymentrequest) if err != nil { return nil, err } c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+name}:resume") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("POST", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "name": c.name, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.patchDeployments.resume" call. // Any non-2xx status code is an error. Response headers are in either // *PatchDeployment.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 (c *ProjectsPatchDeploymentsResumeCall) Do(opts ...googleapi.CallOption) (*PatchDeployment, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &PatchDeployment{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } type ProjectsPatchJobsCancelCall struct { s *Service name string cancelpatchjobrequest *CancelPatchJobRequest urlParams_ gensupport.URLParams ctx_ context.Context header_ http.Header } // Cancel: Cancel a patch job. The patch job must be active. Canceled patch // jobs cannot be restarted. // // - name: Name of the patch in the form `projects/*/patchJobs/*`. func (r *ProjectsPatchJobsService) Cancel(name string, cancelpatchjobrequest *CancelPatchJobRequest) *ProjectsPatchJobsCancelCall { c := &ProjectsPatchJobsCancelCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.name = name c.cancelpatchjobrequest = cancelpatchjobrequest return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsPatchJobsCancelCall) Fields(s ...googleapi.Field) *ProjectsPatchJobsCancelCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsPatchJobsCancelCall) Context(ctx context.Context) *ProjectsPatchJobsCancelCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsPatchJobsCancelCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsPatchJobsCancelCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "application/json", c.header_) var body io.Reader = nil body, err := googleapi.WithoutDataWrapper.JSONReader(c.cancelpatchjobrequest) if err != nil { return nil, err } c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+name}:cancel") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("POST", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "name": c.name, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.patchJobs.cancel" call. // Any non-2xx status code is an error. Response headers are in either // *PatchJob.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 (c *ProjectsPatchJobsCancelCall) Do(opts ...googleapi.CallOption) (*PatchJob, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &PatchJob{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } type ProjectsPatchJobsExecuteCall struct { s *Service parent string executepatchjobrequest *ExecutePatchJobRequest urlParams_ gensupport.URLParams ctx_ context.Context header_ http.Header } // Execute: Patch VM instances by creating and running a patch job. // // - parent: The project in which to run this patch in the form `projects/*`. func (r *ProjectsPatchJobsService) Execute(parent string, executepatchjobrequest *ExecutePatchJobRequest) *ProjectsPatchJobsExecuteCall { c := &ProjectsPatchJobsExecuteCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.parent = parent c.executepatchjobrequest = executepatchjobrequest return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsPatchJobsExecuteCall) Fields(s ...googleapi.Field) *ProjectsPatchJobsExecuteCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsPatchJobsExecuteCall) Context(ctx context.Context) *ProjectsPatchJobsExecuteCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsPatchJobsExecuteCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsPatchJobsExecuteCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "application/json", c.header_) var body io.Reader = nil body, err := googleapi.WithoutDataWrapper.JSONReader(c.executepatchjobrequest) if err != nil { return nil, err } c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+parent}/patchJobs:execute") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("POST", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "parent": c.parent, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.patchJobs.execute" call. // Any non-2xx status code is an error. Response headers are in either // *PatchJob.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 (c *ProjectsPatchJobsExecuteCall) Do(opts ...googleapi.CallOption) (*PatchJob, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &PatchJob{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } type ProjectsPatchJobsGetCall struct { s *Service name string urlParams_ gensupport.URLParams ifNoneMatch_ string ctx_ context.Context header_ http.Header } // Get: Get the patch job. This can be used to track the progress of an ongoing // patch job or review the details of completed jobs. // // - name: Name of the patch in the form `projects/*/patchJobs/*`. func (r *ProjectsPatchJobsService) Get(name string) *ProjectsPatchJobsGetCall { c := &ProjectsPatchJobsGetCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.name = name return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsPatchJobsGetCall) Fields(s ...googleapi.Field) *ProjectsPatchJobsGetCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // IfNoneMatch sets an 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. func (c *ProjectsPatchJobsGetCall) IfNoneMatch(entityTag string) *ProjectsPatchJobsGetCall { c.ifNoneMatch_ = entityTag return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsPatchJobsGetCall) Context(ctx context.Context) *ProjectsPatchJobsGetCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsPatchJobsGetCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsPatchJobsGetCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "", c.header_) if c.ifNoneMatch_ != "" { reqHeaders.Set("If-None-Match", c.ifNoneMatch_) } var body io.Reader = nil c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+name}") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("GET", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "name": c.name, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.patchJobs.get" call. // Any non-2xx status code is an error. Response headers are in either // *PatchJob.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 (c *ProjectsPatchJobsGetCall) Do(opts ...googleapi.CallOption) (*PatchJob, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &PatchJob{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } type ProjectsPatchJobsListCall struct { s *Service parent string urlParams_ gensupport.URLParams ifNoneMatch_ string ctx_ context.Context header_ http.Header } // List: Get a list of patch jobs. // // - parent: In the form of `projects/*`. func (r *ProjectsPatchJobsService) List(parent string) *ProjectsPatchJobsListCall { c := &ProjectsPatchJobsListCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.parent = parent return c } // Filter sets the optional parameter "filter": If provided, this field // specifies the criteria that must be met by patch jobs to be included in the // response. Currently, filtering is only available on the patch_deployment // field. func (c *ProjectsPatchJobsListCall) Filter(filter string) *ProjectsPatchJobsListCall { c.urlParams_.Set("filter", filter) return c } // PageSize sets the optional parameter "pageSize": The maximum number of // instance status to return. func (c *ProjectsPatchJobsListCall) PageSize(pageSize int64) *ProjectsPatchJobsListCall { c.urlParams_.Set("pageSize", fmt.Sprint(pageSize)) return c } // PageToken sets the optional parameter "pageToken": A pagination token // returned from a previous call that indicates where this listing should // continue from. func (c *ProjectsPatchJobsListCall) PageToken(pageToken string) *ProjectsPatchJobsListCall { c.urlParams_.Set("pageToken", pageToken) return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsPatchJobsListCall) Fields(s ...googleapi.Field) *ProjectsPatchJobsListCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // IfNoneMatch sets an 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. func (c *ProjectsPatchJobsListCall) IfNoneMatch(entityTag string) *ProjectsPatchJobsListCall { c.ifNoneMatch_ = entityTag return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsPatchJobsListCall) Context(ctx context.Context) *ProjectsPatchJobsListCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsPatchJobsListCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsPatchJobsListCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "", c.header_) if c.ifNoneMatch_ != "" { reqHeaders.Set("If-None-Match", c.ifNoneMatch_) } var body io.Reader = nil c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+parent}/patchJobs") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("GET", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "parent": c.parent, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.patchJobs.list" call. // Any non-2xx status code is an error. Response headers are in either // *ListPatchJobsResponse.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 (c *ProjectsPatchJobsListCall) Do(opts ...googleapi.CallOption) (*ListPatchJobsResponse, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &ListPatchJobsResponse{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } // 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. func (c *ProjectsPatchJobsListCall) Pages(ctx context.Context, f func(*ListPatchJobsResponse) error) error { c.ctx_ = ctx defer c.PageToken(c.urlParams_.Get("pageToken")) for { x, err := c.Do() if err != nil { return err } if err := f(x); err != nil { return err } if x.NextPageToken == "" { return nil } c.PageToken(x.NextPageToken) } } type ProjectsPatchJobsInstanceDetailsListCall struct { s *Service parent string urlParams_ gensupport.URLParams ifNoneMatch_ string ctx_ context.Context header_ http.Header } // List: Get a list of instance details for a given patch job. // // - parent: The parent for the instances are in the form of // `projects/*/patchJobs/*`. func (r *ProjectsPatchJobsInstanceDetailsService) List(parent string) *ProjectsPatchJobsInstanceDetailsListCall { c := &ProjectsPatchJobsInstanceDetailsListCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.parent = parent return c } // Filter sets the optional parameter "filter": A filter expression that // filters results listed in the response. This field supports filtering // results by instance zone, name, state, or `failure_reason`. func (c *ProjectsPatchJobsInstanceDetailsListCall) Filter(filter string) *ProjectsPatchJobsInstanceDetailsListCall { c.urlParams_.Set("filter", filter) return c } // PageSize sets the optional parameter "pageSize": The maximum number of // instance details records to return. Default is 100. func (c *ProjectsPatchJobsInstanceDetailsListCall) PageSize(pageSize int64) *ProjectsPatchJobsInstanceDetailsListCall { c.urlParams_.Set("pageSize", fmt.Sprint(pageSize)) return c } // PageToken sets the optional parameter "pageToken": A pagination token // returned from a previous call that indicates where this listing should // continue from. func (c *ProjectsPatchJobsInstanceDetailsListCall) PageToken(pageToken string) *ProjectsPatchJobsInstanceDetailsListCall { c.urlParams_.Set("pageToken", pageToken) return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsPatchJobsInstanceDetailsListCall) Fields(s ...googleapi.Field) *ProjectsPatchJobsInstanceDetailsListCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // IfNoneMatch sets an 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. func (c *ProjectsPatchJobsInstanceDetailsListCall) IfNoneMatch(entityTag string) *ProjectsPatchJobsInstanceDetailsListCall { c.ifNoneMatch_ = entityTag return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsPatchJobsInstanceDetailsListCall) Context(ctx context.Context) *ProjectsPatchJobsInstanceDetailsListCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsPatchJobsInstanceDetailsListCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsPatchJobsInstanceDetailsListCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "", c.header_) if c.ifNoneMatch_ != "" { reqHeaders.Set("If-None-Match", c.ifNoneMatch_) } var body io.Reader = nil c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+parent}/instanceDetails") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("GET", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "parent": c.parent, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.patchJobs.instanceDetails.list" call. // Any non-2xx status code is an error. Response headers are in either // *ListPatchJobInstanceDetailsResponse.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 (c *ProjectsPatchJobsInstanceDetailsListCall) Do(opts ...googleapi.CallOption) (*ListPatchJobInstanceDetailsResponse, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &ListPatchJobInstanceDetailsResponse{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil } // 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. func (c *ProjectsPatchJobsInstanceDetailsListCall) Pages(ctx context.Context, f func(*ListPatchJobInstanceDetailsResponse) error) error { c.ctx_ = ctx defer c.PageToken(c.urlParams_.Get("pageToken")) for { x, err := c.Do() if err != nil { return err } if err := f(x); err != nil { return err } if x.NextPageToken == "" { return nil } c.PageToken(x.NextPageToken) } } type ProjectsZonesInstancesLookupEffectiveGuestPolicyCall struct { s *Service instance string lookupeffectiveguestpolicyrequest *LookupEffectiveGuestPolicyRequest urlParams_ gensupport.URLParams ctx_ context.Context header_ http.Header } // LookupEffectiveGuestPolicy: Lookup the effective guest policy that applies // to a VM instance. This lookup merges all policies that are assigned to the // instance ancestry. // // - instance: The VM instance whose policies are being looked up. func (r *ProjectsZonesInstancesService) LookupEffectiveGuestPolicy(instance string, lookupeffectiveguestpolicyrequest *LookupEffectiveGuestPolicyRequest) *ProjectsZonesInstancesLookupEffectiveGuestPolicyCall { c := &ProjectsZonesInstancesLookupEffectiveGuestPolicyCall{s: r.s, urlParams_: make(gensupport.URLParams)} c.instance = instance c.lookupeffectiveguestpolicyrequest = lookupeffectiveguestpolicyrequest return c } // Fields allows partial responses to be retrieved. See // https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more // details. func (c *ProjectsZonesInstancesLookupEffectiveGuestPolicyCall) Fields(s ...googleapi.Field) *ProjectsZonesInstancesLookupEffectiveGuestPolicyCall { c.urlParams_.Set("fields", googleapi.CombineFields(s)) return c } // Context sets the context to be used in this call's Do method. func (c *ProjectsZonesInstancesLookupEffectiveGuestPolicyCall) Context(ctx context.Context) *ProjectsZonesInstancesLookupEffectiveGuestPolicyCall { c.ctx_ = ctx return c } // Header returns a http.Header that can be modified by the caller to add // headers to the request. func (c *ProjectsZonesInstancesLookupEffectiveGuestPolicyCall) Header() http.Header { if c.header_ == nil { c.header_ = make(http.Header) } return c.header_ } func (c *ProjectsZonesInstancesLookupEffectiveGuestPolicyCall) doRequest(alt string) (*http.Response, error) { reqHeaders := gensupport.SetHeaders(c.s.userAgent(), "application/json", c.header_) var body io.Reader = nil body, err := googleapi.WithoutDataWrapper.JSONReader(c.lookupeffectiveguestpolicyrequest) if err != nil { return nil, err } c.urlParams_.Set("alt", alt) c.urlParams_.Set("prettyPrint", "false") urls := googleapi.ResolveRelative(c.s.BasePath, "v1beta/{+instance}:lookupEffectiveGuestPolicy") urls += "?" + c.urlParams_.Encode() req, err := http.NewRequest("POST", urls, body) if err != nil { return nil, err } req.Header = reqHeaders googleapi.Expand(req.URL, map[string]string{ "instance": c.instance, }) return gensupport.SendRequest(c.ctx_, c.s.client, req) } // Do executes the "osconfig.projects.zones.instances.lookupEffectiveGuestPolicy" call. // Any non-2xx status code is an error. Response headers are in either // *EffectiveGuestPolicy.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 (c *ProjectsZonesInstancesLookupEffectiveGuestPolicyCall) Do(opts ...googleapi.CallOption) (*EffectiveGuestPolicy, error) { gensupport.SetOptions(c.urlParams_, opts...) res, err := c.doRequest("json") if res != nil && res.StatusCode == http.StatusNotModified { if res.Body != nil { res.Body.Close() } return nil, gensupport.WrapError(&googleapi.Error{ Code: res.StatusCode, Header: res.Header, }) } if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, gensupport.WrapError(err) } ret := &EffectiveGuestPolicy{ ServerResponse: googleapi.ServerResponse{ Header: res.Header, HTTPStatusCode: res.StatusCode, }, } target := &ret if err := gensupport.DecodeResponse(target, res); err != nil { return nil, err } return ret, nil }