123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479 |
- syntax = "proto3";
- package google.cloud.orgpolicy.v2;
- import "google/api/annotations.proto";
- import "google/api/client.proto";
- import "google/api/field_behavior.proto";
- import "google/api/resource.proto";
- import "google/cloud/orgpolicy/v2/constraint.proto";
- import "google/protobuf/empty.proto";
- import "google/protobuf/timestamp.proto";
- import "google/type/expr.proto";
- option csharp_namespace = "Google.Cloud.OrgPolicy.V2";
- option go_package = "google.golang.org/genproto/googleapis/cloud/orgpolicy/v2;orgpolicy";
- option java_multiple_files = true;
- option java_outer_classname = "OrgPolicyProto";
- option java_package = "com.google.cloud.orgpolicy.v2";
- option php_namespace = "Google\\Cloud\\OrgPolicy\\V2";
- option ruby_package = "Google::Cloud::OrgPolicy::V2";
- service OrgPolicy {
- option (google.api.default_host) = "orgpolicy.googleapis.com";
- option (google.api.oauth_scopes) = "https://www.googleapis.com/auth/cloud-platform";
-
- rpc ListConstraints(ListConstraintsRequest) returns (ListConstraintsResponse) {
- option (google.api.http) = {
- get: "/v2/{parent=projects/*}/constraints"
- additional_bindings {
- get: "/v2/{parent=folders/*}/constraints"
- }
- additional_bindings {
- get: "/v2/{parent=organizations/*}/constraints"
- }
- };
- option (google.api.method_signature) = "parent";
- }
-
- rpc ListPolicies(ListPoliciesRequest) returns (ListPoliciesResponse) {
- option (google.api.http) = {
- get: "/v2/{parent=projects/*}/policies"
- additional_bindings {
- get: "/v2/{parent=folders/*}/policies"
- }
- additional_bindings {
- get: "/v2/{parent=organizations/*}/policies"
- }
- };
- option (google.api.method_signature) = "parent";
- }
-
-
-
-
-
- rpc GetPolicy(GetPolicyRequest) returns (Policy) {
- option (google.api.http) = {
- get: "/v2/{name=projects/*/policies/*}"
- additional_bindings {
- get: "/v2/{name=folders/*/policies/*}"
- }
- additional_bindings {
- get: "/v2/{name=organizations/*/policies/*}"
- }
- };
- option (google.api.method_signature) = "name";
- }
-
-
-
-
-
-
- rpc GetEffectivePolicy(GetEffectivePolicyRequest) returns (Policy) {
- option (google.api.http) = {
- get: "/v2/{name=projects/*/policies/*}:getEffectivePolicy"
- additional_bindings {
- get: "/v2/{name=folders/*/policies/*}:getEffectivePolicy"
- }
- additional_bindings {
- get: "/v2/{name=organizations/*/policies/*}:getEffectivePolicy"
- }
- };
- option (google.api.method_signature) = "name";
- }
-
-
-
-
-
-
- rpc CreatePolicy(CreatePolicyRequest) returns (Policy) {
- option (google.api.http) = {
- post: "/v2/{parent=projects/*}/policies"
- body: "policy"
- additional_bindings {
- post: "/v2/{parent=folders/*}/policies"
- body: "policy"
- }
- additional_bindings {
- post: "/v2/{parent=organizations/*}/policies"
- body: "policy"
- }
- };
- option (google.api.method_signature) = "parent,policy";
- }
-
-
-
-
-
-
-
-
-
- rpc UpdatePolicy(UpdatePolicyRequest) returns (Policy) {
- option (google.api.http) = {
- patch: "/v2/{policy.name=projects/*/policies/*}"
- body: "policy"
- additional_bindings {
- patch: "/v2/{policy.name=folders/*/policies/*}"
- body: "policy"
- }
- additional_bindings {
- patch: "/v2/{policy.name=organizations/*/policies/*}"
- body: "policy"
- }
- };
- option (google.api.method_signature) = "policy";
- }
-
-
-
-
- rpc DeletePolicy(DeletePolicyRequest) returns (google.protobuf.Empty) {
- option (google.api.http) = {
- delete: "/v2/{name=projects/*/policies/*}"
- additional_bindings {
- delete: "/v2/{name=folders/*/policies/*}"
- }
- additional_bindings {
- delete: "/v2/{name=organizations/*/policies/*}"
- }
- };
- option (google.api.method_signature) = "name";
- }
- }
- message Policy {
- option (google.api.resource) = {
- type: "orgpolicy.googleapis.com/Policy"
- pattern: "projects/{project}/policies/{policy}"
- pattern: "folders/{folder}/policies/{policy}"
- pattern: "organizations/{organization}/policies/{policy}"
- };
-
-
-
-
-
-
-
-
-
-
-
-
- string name = 1 [(google.api.field_behavior) = IMMUTABLE];
-
- PolicySpec spec = 2;
-
- AlternatePolicySpec alternate = 3 [deprecated = true];
- }
- message AlternatePolicySpec {
-
-
-
- string launch = 1;
-
- PolicySpec spec = 2;
- }
- message PolicySpec {
-
- message PolicyRule {
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- message StringValues {
-
- repeated string allowed_values = 1;
-
- repeated string denied_values = 2;
- }
- oneof kind {
-
-
- StringValues values = 1;
-
-
- bool allow_all = 2;
-
-
- bool deny_all = 3;
-
-
-
- bool enforce = 4;
- }
-
-
-
-
-
-
-
-
-
-
-
-
- google.type.Expr condition = 5;
- }
-
-
-
-
-
-
-
-
-
-
-
- string etag = 1;
-
-
-
- google.protobuf.Timestamp update_time = 2 [(google.api.field_behavior) = OUTPUT_ONLY];
-
-
-
-
-
-
-
-
- repeated PolicyRule rules = 3;
-
-
-
-
-
-
-
- bool inherit_from_parent = 4;
-
-
-
-
-
-
- bool reset = 5;
- }
- message ListConstraintsRequest {
-
-
-
-
-
-
- string parent = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- child_type: "orgpolicy.googleapis.com/Constraint"
- }
- ];
-
-
-
- int32 page_size = 2;
-
-
- string page_token = 3;
- }
- message ListConstraintsResponse {
-
- repeated Constraint constraints = 1;
-
- string next_page_token = 2;
- }
- message ListPoliciesRequest {
-
-
-
-
-
-
-
- string parent = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- child_type: "orgpolicy.googleapis.com/Policy"
- }
- ];
-
-
-
- int32 page_size = 2;
-
-
- string page_token = 3;
- }
- message ListPoliciesResponse {
-
-
- repeated Policy policies = 1;
-
-
- string next_page_token = 2;
- }
- message GetPolicyRequest {
-
- string name = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- type: "orgpolicy.googleapis.com/Policy"
- }
- ];
- }
- message GetEffectivePolicyRequest {
-
- string name = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- type: "orgpolicy.googleapis.com/Policy"
- }
- ];
- }
- message CreatePolicyRequest {
-
-
-
-
-
-
- string parent = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- child_type: "orgpolicy.googleapis.com/Policy"
- }
- ];
-
- Policy policy = 3 [(google.api.field_behavior) = REQUIRED];
- }
- message UpdatePolicyRequest {
-
- Policy policy = 1 [(google.api.field_behavior) = REQUIRED];
- }
- message DeletePolicyRequest {
-
-
- string name = 1 [
- (google.api.field_behavior) = REQUIRED,
- (google.api.resource_reference) = {
- type: "orgpolicy.googleapis.com/Policy"
- }
- ];
- }
|