apigateway.proto 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632
  1. // Copyright 2021 Google LLC
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. syntax = "proto3";
  15. package google.cloud.apigateway.v1;
  16. import "google/api/field_behavior.proto";
  17. import "google/api/resource.proto";
  18. import "google/protobuf/field_mask.proto";
  19. import "google/protobuf/timestamp.proto";
  20. option csharp_namespace = "Google.Cloud.ApiGateway.V1";
  21. option go_package = "google.golang.org/genproto/googleapis/cloud/apigateway/v1;apigateway";
  22. option java_multiple_files = true;
  23. option java_package = "com.google.cloud.apigateway.v1";
  24. option php_namespace = "Google\\Cloud\\ApiGateway\\V1";
  25. option ruby_package = "Google::Cloud::ApiGateway::V1";
  26. option (google.api.resource_definition) = {
  27. type: "iam.googleapis.com/ServiceAccount"
  28. pattern: "projects/{project}/serviceAccounts/{service_account}"
  29. };
  30. option (google.api.resource_definition) = {
  31. type: "servicemanagement.googleapis.com/ManagedService"
  32. pattern: "services/{service}"
  33. };
  34. option (google.api.resource_definition) = {
  35. type: "servicemanagement.googleapis.com/Service"
  36. pattern: "services/{service}/configs/{config}"
  37. };
  38. // An API that can be served by one or more Gateways.
  39. message Api {
  40. option (google.api.resource) = {
  41. type: "apigateway.googleapis.com/Api"
  42. pattern: "projects/{project}/locations/global/apis/{api}"
  43. };
  44. // All the possible API states.
  45. enum State {
  46. // API does not have a state yet.
  47. STATE_UNSPECIFIED = 0;
  48. // API is being created.
  49. CREATING = 1;
  50. // API is active.
  51. ACTIVE = 2;
  52. // API creation failed.
  53. FAILED = 3;
  54. // API is being deleted.
  55. DELETING = 4;
  56. // API is being updated.
  57. UPDATING = 5;
  58. }
  59. // Output only. Resource name of the API.
  60. // Format: projects/{project}/locations/global/apis/{api}
  61. string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY];
  62. // Output only. Created time.
  63. google.protobuf.Timestamp create_time = 2 [(google.api.field_behavior) = OUTPUT_ONLY];
  64. // Output only. Updated time.
  65. google.protobuf.Timestamp update_time = 3 [(google.api.field_behavior) = OUTPUT_ONLY];
  66. // Optional. Resource labels to represent user-provided metadata.
  67. // Refer to cloud documentation on labels for more details.
  68. // https://cloud.google.com/compute/docs/labeling-resources
  69. map<string, string> labels = 4 [(google.api.field_behavior) = OPTIONAL];
  70. // Optional. Display name.
  71. string display_name = 5 [(google.api.field_behavior) = OPTIONAL];
  72. // Optional. Immutable. The name of a Google Managed Service (
  73. // https://cloud.google.com/service-infrastructure/docs/glossary#managed). If
  74. // not specified, a new Service will automatically be created in the same
  75. // project as this API.
  76. string managed_service = 7 [
  77. (google.api.field_behavior) = IMMUTABLE,
  78. (google.api.field_behavior) = OPTIONAL,
  79. (google.api.resource_reference) = {
  80. type: "servicemanagement.googleapis.com/ManagedService"
  81. }
  82. ];
  83. // Output only. State of the API.
  84. State state = 12 [(google.api.field_behavior) = OUTPUT_ONLY];
  85. }
  86. // An API Configuration is a combination of settings for both the Managed
  87. // Service and Gateways serving this API Config.
  88. message ApiConfig {
  89. option (google.api.resource) = {
  90. type: "apigateway.googleapis.com/ApiConfig"
  91. pattern: "projects/{project}/locations/global/apis/{api}/configs/{api_config}"
  92. };
  93. // A lightweight description of a file.
  94. message File {
  95. // The file path (full or relative path). This is typically the path of the
  96. // file when it is uploaded.
  97. string path = 1;
  98. // The bytes that constitute the file.
  99. bytes contents = 2;
  100. }
  101. // An OpenAPI Specification Document describing an API.
  102. message OpenApiDocument {
  103. // The OpenAPI Specification document file.
  104. File document = 1;
  105. }
  106. // A gRPC service definition.
  107. message GrpcServiceDefinition {
  108. // Input only. File descriptor set, generated by protoc.
  109. //
  110. // To generate, use protoc with imports and source info included.
  111. // For an example test.proto file, the following command would put the value
  112. // in a new file named out.pb.
  113. //
  114. // $ protoc --include_imports --include_source_info test.proto -o out.pb
  115. File file_descriptor_set = 1 [(google.api.field_behavior) = INPUT_ONLY];
  116. // Optional. Uncompiled proto files associated with the descriptor set, used for
  117. // display purposes (server-side compilation is not supported). These
  118. // should match the inputs to 'protoc' command used to generate
  119. // file_descriptor_set.
  120. repeated File source = 2 [(google.api.field_behavior) = OPTIONAL];
  121. }
  122. // All the possible API Config states.
  123. enum State {
  124. // API Config does not have a state yet.
  125. STATE_UNSPECIFIED = 0;
  126. // API Config is being created and deployed to the API Controller.
  127. CREATING = 1;
  128. // API Config is ready for use by Gateways.
  129. ACTIVE = 2;
  130. // API Config creation failed.
  131. FAILED = 3;
  132. // API Config is being deleted.
  133. DELETING = 4;
  134. // API Config is being updated.
  135. UPDATING = 5;
  136. // API Config settings are being activated in downstream systems.
  137. // API Configs in this state cannot be used by Gateways.
  138. ACTIVATING = 6;
  139. }
  140. // Output only. Resource name of the API Config.
  141. // Format: projects/{project}/locations/global/apis/{api}/configs/{api_config}
  142. string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY];
  143. // Output only. Created time.
  144. google.protobuf.Timestamp create_time = 2 [(google.api.field_behavior) = OUTPUT_ONLY];
  145. // Output only. Updated time.
  146. google.protobuf.Timestamp update_time = 3 [(google.api.field_behavior) = OUTPUT_ONLY];
  147. // Optional. Resource labels to represent user-provided metadata.
  148. // Refer to cloud documentation on labels for more details.
  149. // https://cloud.google.com/compute/docs/labeling-resources
  150. map<string, string> labels = 4 [(google.api.field_behavior) = OPTIONAL];
  151. // Optional. Display name.
  152. string display_name = 5 [(google.api.field_behavior) = OPTIONAL];
  153. // Immutable. The Google Cloud IAM Service Account that Gateways serving this config
  154. // should use to authenticate to other services. This may either be the
  155. // Service Account's email
  156. // (`{ACCOUNT_ID}@{PROJECT}.iam.gserviceaccount.com`) or its full resource
  157. // name (`projects/{PROJECT}/accounts/{UNIQUE_ID}`). This is most often used
  158. // when the service is a GCP resource such as a Cloud Run Service or an
  159. // IAP-secured service.
  160. string gateway_service_account = 14 [
  161. (google.api.field_behavior) = IMMUTABLE,
  162. (google.api.resource_reference) = {
  163. type: "iam.googleapis.com/ServiceAccount"
  164. }
  165. ];
  166. // Output only. The ID of the associated Service Config (
  167. // https://cloud.google.com/service-infrastructure/docs/glossary#config).
  168. string service_config_id = 12 [
  169. (google.api.field_behavior) = OUTPUT_ONLY,
  170. (google.api.resource_reference) = {
  171. type: "servicemanagement.googleapis.com/Service"
  172. }
  173. ];
  174. // Output only. State of the API Config.
  175. State state = 8 [(google.api.field_behavior) = OUTPUT_ONLY];
  176. // Optional. OpenAPI specification documents. If specified, grpc_services and
  177. // managed_service_configs must not be included.
  178. repeated OpenApiDocument openapi_documents = 9 [(google.api.field_behavior) = OPTIONAL];
  179. // Optional. gRPC service definition files. If specified, openapi_documents must
  180. // not be included.
  181. repeated GrpcServiceDefinition grpc_services = 10 [(google.api.field_behavior) = OPTIONAL];
  182. // Optional. Service Configuration files. At least one must be included when using gRPC
  183. // service definitions. See
  184. // https://cloud.google.com/endpoints/docs/grpc/grpc-service-config#service_configuration_overview
  185. // for the expected file contents.
  186. //
  187. // If multiple files are specified, the files are merged with the following
  188. // rules:
  189. // * All singular scalar fields are merged using "last one wins" semantics in
  190. // the order of the files uploaded.
  191. // * Repeated fields are concatenated.
  192. // * Singular embedded messages are merged using these rules for nested
  193. // fields.
  194. repeated File managed_service_configs = 11 [(google.api.field_behavior) = OPTIONAL];
  195. }
  196. // A Gateway is an API-aware HTTP proxy. It performs API-Method and/or
  197. // API-Consumer specific actions based on an API Config such as authentication,
  198. // policy enforcement, and backend selection.
  199. message Gateway {
  200. option (google.api.resource) = {
  201. type: "apigateway.googleapis.com/Gateway"
  202. pattern: "projects/{project}/locations/{location}/gateways/{gateway}"
  203. };
  204. // All the possible Gateway states.
  205. enum State {
  206. // Gateway does not have a state yet.
  207. STATE_UNSPECIFIED = 0;
  208. // Gateway is being created.
  209. CREATING = 1;
  210. // Gateway is running and ready for requests.
  211. ACTIVE = 2;
  212. // Gateway creation failed.
  213. FAILED = 3;
  214. // Gateway is being deleted.
  215. DELETING = 4;
  216. // Gateway is being updated.
  217. UPDATING = 5;
  218. }
  219. // Output only. Resource name of the Gateway.
  220. // Format: projects/{project}/locations/{location}/gateways/{gateway}
  221. string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY];
  222. // Output only. Created time.
  223. google.protobuf.Timestamp create_time = 2 [(google.api.field_behavior) = OUTPUT_ONLY];
  224. // Output only. Updated time.
  225. google.protobuf.Timestamp update_time = 3 [(google.api.field_behavior) = OUTPUT_ONLY];
  226. // Optional. Resource labels to represent user-provided metadata.
  227. // Refer to cloud documentation on labels for more details.
  228. // https://cloud.google.com/compute/docs/labeling-resources
  229. map<string, string> labels = 4 [(google.api.field_behavior) = OPTIONAL];
  230. // Optional. Display name.
  231. string display_name = 5 [(google.api.field_behavior) = OPTIONAL];
  232. // Required. Resource name of the API Config for this Gateway.
  233. // Format: projects/{project}/locations/global/apis/{api}/configs/{apiConfig}
  234. string api_config = 6 [
  235. (google.api.field_behavior) = REQUIRED,
  236. (google.api.resource_reference) = {
  237. type: "apigateway.googleapis.com/ApiConfig"
  238. }
  239. ];
  240. // Output only. The current state of the Gateway.
  241. State state = 7 [(google.api.field_behavior) = OUTPUT_ONLY];
  242. // Output only. The default API Gateway host name of the form
  243. // `{gateway_id}-{hash}.{region_code}.gateway.dev`.
  244. string default_hostname = 9 [(google.api.field_behavior) = OUTPUT_ONLY];
  245. }
  246. // Request message for ApiGatewayService.ListGateways
  247. message ListGatewaysRequest {
  248. // Required. Parent resource of the Gateway, of the form:
  249. // `projects/*/locations/*`
  250. string parent = 1 [
  251. (google.api.field_behavior) = REQUIRED,
  252. (google.api.resource_reference) = {
  253. type: "locations.googleapis.com/Location"
  254. }
  255. ];
  256. // Page size.
  257. int32 page_size = 2;
  258. // Page token.
  259. string page_token = 3;
  260. // Filter.
  261. string filter = 4;
  262. // Order by parameters.
  263. string order_by = 5;
  264. }
  265. // Response message for ApiGatewayService.ListGateways
  266. message ListGatewaysResponse {
  267. // Gateways.
  268. repeated Gateway gateways = 1;
  269. // Next page token.
  270. string next_page_token = 2;
  271. // Locations that could not be reached.
  272. repeated string unreachable_locations = 3;
  273. }
  274. // Request message for ApiGatewayService.GetGateway
  275. message GetGatewayRequest {
  276. // Required. Resource name of the form:
  277. // `projects/*/locations/*/gateways/*`
  278. string name = 1 [
  279. (google.api.field_behavior) = REQUIRED,
  280. (google.api.resource_reference) = {
  281. type: "apigateway.googleapis.com/Gateway"
  282. }
  283. ];
  284. }
  285. // Request message for ApiGatewayService.CreateGateway
  286. message CreateGatewayRequest {
  287. // Required. Parent resource of the Gateway, of the form:
  288. // `projects/*/locations/*`
  289. string parent = 1 [
  290. (google.api.field_behavior) = REQUIRED,
  291. (google.api.resource_reference) = {
  292. type: "locations.googleapis.com/Location"
  293. }
  294. ];
  295. // Required. Identifier to assign to the Gateway. Must be unique within scope of
  296. // the parent resource.
  297. string gateway_id = 2 [(google.api.field_behavior) = REQUIRED];
  298. // Required. Gateway resource.
  299. Gateway gateway = 3 [(google.api.field_behavior) = REQUIRED];
  300. }
  301. // Request message for ApiGatewayService.UpdateGateway
  302. message UpdateGatewayRequest {
  303. // Field mask is used to specify the fields to be overwritten in the
  304. // Gateway resource by the update.
  305. // The fields specified in the update_mask are relative to the resource, not
  306. // the full request. A field will be overwritten if it is in the mask. If the
  307. // user does not provide a mask then all fields will be overwritten.
  308. google.protobuf.FieldMask update_mask = 1;
  309. // Required. Gateway resource.
  310. Gateway gateway = 2 [(google.api.field_behavior) = REQUIRED];
  311. }
  312. // Request message for ApiGatewayService.DeleteGateway
  313. message DeleteGatewayRequest {
  314. // Required. Resource name of the form:
  315. // `projects/*/locations/*/gateways/*`
  316. string name = 1 [
  317. (google.api.field_behavior) = REQUIRED,
  318. (google.api.resource_reference) = {
  319. type: "apigateway.googleapis.com/Gateway"
  320. }
  321. ];
  322. }
  323. // Request message for ApiGatewayService.ListApis
  324. message ListApisRequest {
  325. // Required. Parent resource of the API, of the form:
  326. // `projects/*/locations/global`
  327. string parent = 1 [
  328. (google.api.field_behavior) = REQUIRED,
  329. (google.api.resource_reference) = {
  330. type: "locations.googleapis.com/Location"
  331. }
  332. ];
  333. // Page size.
  334. int32 page_size = 2;
  335. // Page token.
  336. string page_token = 3;
  337. // Filter.
  338. string filter = 4;
  339. // Order by parameters.
  340. string order_by = 5;
  341. }
  342. // Response message for ApiGatewayService.ListApis
  343. message ListApisResponse {
  344. // APIs.
  345. repeated Api apis = 1;
  346. // Next page token.
  347. string next_page_token = 2;
  348. // Locations that could not be reached.
  349. repeated string unreachable_locations = 3;
  350. }
  351. // Request message for ApiGatewayService.GetApi
  352. message GetApiRequest {
  353. // Required. Resource name of the form:
  354. // `projects/*/locations/global/apis/*`
  355. string name = 1 [
  356. (google.api.field_behavior) = REQUIRED,
  357. (google.api.resource_reference) = {
  358. type: "apigateway.googleapis.com/Api"
  359. }
  360. ];
  361. }
  362. // Request message for ApiGatewayService.CreateApi
  363. message CreateApiRequest {
  364. // Required. Parent resource of the API, of the form:
  365. // `projects/*/locations/global`
  366. string parent = 1 [
  367. (google.api.field_behavior) = REQUIRED,
  368. (google.api.resource_reference) = {
  369. type: "locations.googleapis.com/Location"
  370. }
  371. ];
  372. // Required. Identifier to assign to the API. Must be unique within scope of
  373. // the parent resource.
  374. string api_id = 2 [(google.api.field_behavior) = REQUIRED];
  375. // Required. API resource.
  376. Api api = 3 [(google.api.field_behavior) = REQUIRED];
  377. }
  378. // Request message for ApiGatewayService.UpdateApi
  379. message UpdateApiRequest {
  380. // Field mask is used to specify the fields to be overwritten in the
  381. // Api resource by the update.
  382. // The fields specified in the update_mask are relative to the resource, not
  383. // the full request. A field will be overwritten if it is in the mask. If the
  384. // user does not provide a mask then all fields will be overwritten.
  385. google.protobuf.FieldMask update_mask = 1;
  386. // Required. API resource.
  387. Api api = 2 [(google.api.field_behavior) = REQUIRED];
  388. }
  389. // Request message for ApiGatewayService.DeleteApi
  390. message DeleteApiRequest {
  391. // Required. Resource name of the form:
  392. // `projects/*/locations/global/apis/*`
  393. string name = 1 [
  394. (google.api.field_behavior) = REQUIRED,
  395. (google.api.resource_reference) = {
  396. type: "apigateway.googleapis.com/Api"
  397. }
  398. ];
  399. }
  400. // Request message for ApiGatewayService.ListApiConfigs
  401. message ListApiConfigsRequest {
  402. // Required. Parent resource of the API Config, of the form:
  403. // `projects/*/locations/global/apis/*`
  404. string parent = 1 [
  405. (google.api.field_behavior) = REQUIRED,
  406. (google.api.resource_reference) = {
  407. type: "apigateway.googleapis.com/Api"
  408. }
  409. ];
  410. // Page size.
  411. int32 page_size = 2;
  412. // Page token.
  413. string page_token = 3;
  414. // Filter.
  415. string filter = 4;
  416. // Order by parameters.
  417. string order_by = 5;
  418. }
  419. // Response message for ApiGatewayService.ListApiConfigs
  420. message ListApiConfigsResponse {
  421. // API Configs.
  422. repeated ApiConfig api_configs = 1;
  423. // Next page token.
  424. string next_page_token = 2;
  425. // Locations that could not be reached.
  426. repeated string unreachable_locations = 3;
  427. }
  428. // Request message for ApiGatewayService.GetApiConfig
  429. message GetApiConfigRequest {
  430. // Enum to control which fields should be included in the response.
  431. enum ConfigView {
  432. CONFIG_VIEW_UNSPECIFIED = 0;
  433. // Do not include configuration source files.
  434. BASIC = 1;
  435. // Include configuration source files.
  436. FULL = 2;
  437. }
  438. // Required. Resource name of the form:
  439. // `projects/*/locations/global/apis/*/configs/*`
  440. string name = 1 [
  441. (google.api.field_behavior) = REQUIRED,
  442. (google.api.resource_reference) = {
  443. type: "apigateway.googleapis.com/ApiConfig"
  444. }
  445. ];
  446. // Specifies which fields of the API Config are returned in the response.
  447. // Defaults to `BASIC` view.
  448. ConfigView view = 3;
  449. }
  450. // Request message for ApiGatewayService.CreateApiConfig
  451. message CreateApiConfigRequest {
  452. // Required. Parent resource of the API Config, of the form:
  453. // `projects/*/locations/global/apis/*`
  454. string parent = 1 [
  455. (google.api.field_behavior) = REQUIRED,
  456. (google.api.resource_reference) = {
  457. type: "apigateway.googleapis.com/Api"
  458. }
  459. ];
  460. // Required. Identifier to assign to the API Config. Must be unique within scope of
  461. // the parent resource.
  462. string api_config_id = 2 [(google.api.field_behavior) = REQUIRED];
  463. // Required. API resource.
  464. ApiConfig api_config = 3 [(google.api.field_behavior) = REQUIRED];
  465. }
  466. // Request message for ApiGatewayService.UpdateApiConfig
  467. message UpdateApiConfigRequest {
  468. // Field mask is used to specify the fields to be overwritten in the
  469. // ApiConfig resource by the update.
  470. // The fields specified in the update_mask are relative to the resource, not
  471. // the full request. A field will be overwritten if it is in the mask. If the
  472. // user does not provide a mask then all fields will be overwritten.
  473. google.protobuf.FieldMask update_mask = 1;
  474. // Required. API Config resource.
  475. ApiConfig api_config = 2 [(google.api.field_behavior) = REQUIRED];
  476. }
  477. // Request message for ApiGatewayService.DeleteApiConfig
  478. message DeleteApiConfigRequest {
  479. // Required. Resource name of the form:
  480. // `projects/*/locations/global/apis/*/configs/*`
  481. string name = 1 [
  482. (google.api.field_behavior) = REQUIRED,
  483. (google.api.resource_reference) = {
  484. type: "apigateway.googleapis.com/ApiConfig"
  485. }
  486. ];
  487. }
  488. // Represents the metadata of the long-running operation.
  489. message OperationMetadata {
  490. // Diagnostic information from configuration processing.
  491. message Diagnostic {
  492. // Location of the diagnostic.
  493. string location = 1;
  494. // The diagnostic message.
  495. string message = 2;
  496. }
  497. // Output only. The time the operation was created.
  498. google.protobuf.Timestamp create_time = 1 [(google.api.field_behavior) = OUTPUT_ONLY];
  499. // Output only. The time the operation finished running.
  500. google.protobuf.Timestamp end_time = 2 [(google.api.field_behavior) = OUTPUT_ONLY];
  501. // Output only. Server-defined resource path for the target of the operation.
  502. string target = 3 [(google.api.field_behavior) = OUTPUT_ONLY];
  503. // Output only. Name of the verb executed by the operation.
  504. string verb = 4 [(google.api.field_behavior) = OUTPUT_ONLY];
  505. // Output only. Human-readable status of the operation, if any.
  506. string status_message = 5 [(google.api.field_behavior) = OUTPUT_ONLY];
  507. // Output only. Identifies whether the user has requested cancellation
  508. // of the operation. Operations that have successfully been cancelled
  509. // have [Operation.error][] value with a [google.rpc.Status.code][google.rpc.Status.code] of 1,
  510. // corresponding to `Code.CANCELLED`.
  511. bool requested_cancellation = 6 [(google.api.field_behavior) = OUTPUT_ONLY];
  512. // Output only. API version used to start the operation.
  513. string api_version = 7 [(google.api.field_behavior) = OUTPUT_ONLY];
  514. // Output only. Diagnostics generated during processing of configuration source files.
  515. repeated Diagnostic diagnostics = 8 [(google.api.field_behavior) = OUTPUT_ONLY];
  516. }